python3字典排序

2021-07-25 17:38:02 字數 1898 閱讀 2354

說實話,對字典進行排序,這個說法本身就有問題,實際上,你無法對操縱字典說,字典,在你的底層實現裡,你就得按照我指定的順序來排列,如果這樣的話,字典就喪失了它的速度優勢,它也不是乙個字典了.

好了,廢話不多說,我這裡稍微記錄一下我的做法吧.

python2裡面原來是有dict.iteritems這樣乙個函式的,但是在python3裡面給消除掉了,dict.itemitems實際返回的是乙個list型別的物件,物件裡面全部是tuple元素,每個tuple都有兩個元素,乙個是key,乙個是value.

python2時代的做法是這麼來排序的:

>> dic

>> sorted(dic.iteritems(), key=lambda x:x[0], reverse=true) # 按照第0個元素降序排列

[('c', 1), ('b', 2), ('a', 3)]

>> sorted(dic.iteritems(), key=lambda x:x[0], reverse=false) # 按照第0個元素公升序排列

[('a', 3), ('b', 2), ('c', 1)]

>> sorted(dic.iteritems(), key=lambda x:x[1], reverse=true) # 按照第1個元素降序排列

[('a', 3), ('b', 2), ('c', 1)]

>> sorted(dic.iteritems(), key=lambda x:x[1], reverse=false) # 按照第1個元素降序排列

[('c', 1), ('b', 2), ('a', 3)]

既然iteritems()函式取消了,我們構建乙個類似的函式即可.

def

dict2list

(dic:dict):

''' 將字典轉化為列表 '''

keys = dic.keys()

vals = dic.values()

lst = [(key, val) for key, val in zip(keys, vals)]

return lst

以後在python3裡面要對字典排個序什麼的,也很簡單:

>> dic

>> sorted(dict2list(dic), key=lambda x:x[0], reverse=true) # 按照第0個元素降序排列

[('c', 1), ('b', 2), ('a', 3)]

>> sorted(dict2list(dic), key=lambda x:x[0], reverse=false) # 按照第0個元素公升序排列

[('a', 3), ('b', 2), ('c', 1)]

>> sorted(dict2list(dic), key=lambda x:x[1], reverse=true) # 按照第1個元素降序排列

[('a', 3), ('b', 2), ('c', 1)]

>> sorted(dict2list(dic), key=lambda x:x[1], reverse=false) # 按照第1個元素降序排列

[('c', 1), ('b', 2), ('a', 3)]

至於效率,你都用python了,還扯什麼效率呢.

當然,也請不要奢望說,返回乙個排序後的字典,前面已經講了,真的沒有意義,你是在追求順序的字典的話,可以使用有序字典,python裡面有這樣的包.

python3字典遍歷 python3字典遍歷

python版本 python3.7 info infog.get name 得到字典info中name的值 info.keys 得到字典info中所有的鍵,結果是乙個物件 dict keys name age 需要注意在python2中該操作得到的是乙個列表 遍歷key for temp in i...

python3字典的排序

dict1 1 取字典的所有鍵,所有的值,利用dict1.keys dict1.vaules 2 同時取字典的鍵 值,dict1.items 3 對字典進行排序 3.1 sorted 預設是對字典的鍵,從小到大進行排序 dict1 dict2 sorted dict1 print dict2 結果 ...

python3 字典的排序

先看一下,直接用sorted 排序的情況。dict1 dict2 sorted dict1 print dict2 結果 a d e f sorted 預設是對字典的鍵,從小到大進行排序 當然我們也可以先拿到所有的key,然後再對key排序 dict1 list1 sorted dict1.keys...