众所周知,python的字典是无序的,虽然python也有有序字典,但其有序是对于key而言的,若想对普通字典按照key或value排序输出,需要一些小技巧,大致思路是利用匿名函数指定排序关键字(可指定多个),再利用内置的sorted函数实现,代码如下:
e.g.1 对单个数值形式的value执行单级排序
d1 = {'a':1, 'b':3, 'c':2}
ordered_d1 = sorted(d1.items(), key=lambda x: x[1]) //x代表每个字典项(tuple形式),若需逆序排,在x[1]前加'-'即可
# output: [('a',1),('c',2),('b',3)]
e.g.2 对key,value进行多级排序
d2 = {'d':[1,1], 'c':[0, 1], 'b':[0, 2], 'a':[1,1]}
# 先按照value(列表)的第二个值升序,再按照第一个值升序,最后再按照key升序
ordered_d2 = sorted(d2.items(), key=lambda x:[x[1][1],x[1][0],x[0]])
# output: [('c', [0, 1]), ('a', [1, 1]), ('d', [1, 1]), ('b', [0, 2])]
此外,还可举一反三,利用max,min等内置函数求字典中key或value最大、最小的key-value对。