對字典進行排序?這實際上是一個僞命題,搞清楚python字典的定義---字典自己默認以key的字符順序輸出顯示---就像咱們用的真實的字典同樣,按照abcd字母的順序排列,而且本質上各自沒有前後關係,是一個哈希表的結構:python
但實際應用中咱們確實有這種排序的「需求」-----按照values的值「排序」輸出,或者按照別的奇怪的順序進行輸出,咱們只須要把字典轉化成list或者tuple,把字典每一對鍵值轉化爲list中的兩位子list或者子tuple再輸出,就能夠達到咱們的目的:spa
舉例以下:code
x={2:1,3:4,4:2,1:5,5:3} import operator sorted_x=sorted(x.items(),key=operator.itemgetter(0))#按照item中的第一個字符進行排序,即按照key排序 print x print sorted_x print dict(sorted_x)
輸出結果爲:blog
{1: 5, 2: 1, 3: 4, 4: 2, 5: 3}
[(1, 5), (2, 1), (3, 4), (4, 2), (5, 3)]
{1: 5, 2: 1, 3: 4, 4: 2, 5: 3}
字典始終都按照key從小到大排序,與定義過程無關,轉化爲list嵌套tuple這裏也依然按着key排序排序
x={2:1,3:4,4:2,1:5,5:3} import operator sorted_x=sorted(x.items(),key=operator.itemgetter(1))#這裏改成按照item的第二個字符排序,即value排序 print x print sorted_x print dict(sorted_x)
輸出結果爲:get
{1: 5, 2: 1, 3: 4, 4: 2, 5: 3} [(2, 1), (4, 2), (5, 3), (3, 4), (1, 5)] {1: 5, 2: 1, 3: 4, 4: 2, 5: 3}
字典的順序依舊不變,但轉化爲list嵌套tuple格式以後,完成了按照value排序的操做it