Python對字典進行排序

Blateyang發表於2018-07-22

眾所周知,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對。

相關文章