標籤:list 目的 一個 ict 輸出 字元 舉例 結構 實際應用
對字典進行排序?這其實是一個偽命題,搞清楚python字典的定義---字典本身預設以key的字元順序輸出顯示---就像我們用的真實的字典一樣,按照abcd字母的順序排列,並且本質上各自沒有先後關係,是一個雜湊表的結構:但實際應用中我們確實有這種排序的“需求”-----按照values的值“排序”輸出,或者按照別的奇怪的順序進行輸出,我們只需要把字典轉化成list或者tuple,把字典每一對索引值轉化為list中的兩位子list或者子tuple再輸出,就可以達到我們的目的:舉例如下:
x={2:1,3:4,4:2,1:5,5:3}import operatorsorted_x=sorted(x.items(),key=operator.itemgetter(0))#按照item中的第一個字元進行排序,即按照key排序print xprint sorted_xprint dict(sorted_x)
輸出結果為:
{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 operatorsorted_x=sorted(x.items(),key=operator.itemgetter(1))#這裡改為按照item的第二個字元排序,即value排序print xprint sorted_xprint dict(sorted_x)
輸出結果為:
{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排序的操作
python 對字典"排序"