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