1.sorted函數按key值對字典排序
先來基本介紹一下sorted函數,sorted(iterable,key,reverse),sorted一共有iterable,key,reverse這三個參數。
要按key值對字典排序,則可以使用如下語句
dic = {'chen': 24, 'alex': 34, 'egon': 37, 'evaJ':'18'}
s_dic = sorted(dic.keys()) # 只對key排序,結果也只有key
print(s_dic)
s_dic1 = sorted(dic.items(), key=lambda x: x[0]) # 結果包含key,和value
print(s_dic1)
# 輸出結果
# ['alex', 'chen', 'egon', 'evaJ']
# [('alex', 34), ('chen', 24), ('egon', 37), ('evaJ', '18')]
直接使用sorted(d.keys())就能按key值對字典排序,這裏是按照順序對key值排序的,如果想按照倒序排序的話,則只要將reverse置爲true即可。
dic = {'chen': 24, 'alex': 34, 'egon': 37, 'evaJ':'18'}
s_dic = sorted(dic.keys(), reverse=True)
# 輸出結果
# ['evaJ', 'egon', 'chen', 'alex']
2.sorted函數按value值對字典排序
要對字典的value排序則需要用到key參數,在這裏主要提供一種使用lambda表達式的方法,如下:
# 現在想對字典進行排序,根據value的第一個值,即列表的第一個數字
test_dict = {
'a': [1, 'n'],
'b': [2, 'k', 'b'],
'c': [5, 'h1', 'h2', 'h3', 'h4', 'h5'],
'd': [3, 'dfg1', 'dfg2', 'df3'],
'e': [4, 'dfg1', 'dfg2', 'dfg3', 'dfg4'],
'f': [2, 'dfgl', 'dfg2'],
'g': [2, 'f1', 'f2'],
}
tmp = sorted(test_dict.items(), reverse=True, key=lambda x: x[1][0])
# >>> test_dict.items()
# dict_items([('a', [1, 'n']), ('b', [2, 'k']), ('c', [5, 'h']), ('d', [10, 'dfg']), ('e', [4, 'dfg']), ('f', [2, 'dfgl']), ('g', [2, 'f'])])
# 這裏的test_dict.items()實際上是將test_dict轉換爲可迭代對象
# ('a', [1, 'n']), ('b', [2, 'k']), ('c', [5, 'h']), ('d', [10, 'dfg']), ('e', [4, 'dfg']), ('f', [2, 'dfgl']), ('g', [2, 'f'])
# 用的是元組的第二值,即列表,取列表的第一個值,就是需要排列的數字,key=lambda x: x[1][0]
# print(tmp)
for i in tmp:
print(i[1][0],i[0])
for n, u in enumerate(i[1][1:], 1):
print('\t', n, u)
# 輸出結果
# 5 c
# 1 h1
# 2 h2
# 3 h3
# 4 h4
# 5 h5
# 4 e
# 1 dfg1
# 2 dfg2
# 3 dfg3
# 4 dfg4
# 3 d
# 1 dfg1
# 2 dfg2
# 3 df3
# 2 b
# 1 k
# 2 b
# 2 f
# 1 dfgl
# 2 dfg2
# 2 g
# 1 f1
# 2 f2
# 1 a
# 1 n