Python 字典排序

2021-08-21 18:57:57 字數 2544 閱讀 2828

1、 準備知識:

在python裡,字典dictionary是內建的資料型別,是個無序的儲存結構,每一元素是key-value對:

如:dict = ,其中『username』和『password』是key,而『xiaoming』和『123456』是value,可以通過d[key]獲得對應值value的引用,但是不能通過value得到key。

對於dictionnary,需知道以下幾點注意事項:

a、 dictionary 的 key 是大小寫敏感的;

b、 乙個dictionary中不能有重複的 key;

c、 dictionary是無序的,沒有元素順序的概念,它們只是序偶的簡單排列。

2、 字典按鍵/值進行排序:

dictionary本身沒有順序概念,但是總是在某些時候,但是我們常常需要對字典進行排序

方法1:按照key值排序。

def sorteddictvalues1(adict):

items = adict.items()

print "items:",items

items.sort()

return [value for key, value in items]

adict =

print sorteddictvalues1(adict)

items: [('a1', 11), ('c1', 30), ('e1', 20), ('b1', 2), ('d1', 4)]

[11, 2, 30, 4, 20]

字典的items方法,會返回乙個元組的列表,其中每個元組都包含一對專案——鍵與對應的值。元組列表可以sort()方法排序。

方法2:按照key值排序

def sorteddictvalues2(adict): 

keys = adict.keys()

keys.sort()

return [dict[key] for key in keys]

字典物件的keys()方法返回字典中所有鍵值組成的列表,次序是隨機的。需要排序時只要對返回的鍵值列表使用sort()方法,速度比方法1快。

方法3:按照key值排序

def sorteddictvalues3(adict): 

keys = adict.keys()

keys.sort()

return map(adict.get, keys)

通過對映的方法去更有效的執行最後一步

方法4:一行語句

[(k,di[k]) for k in sorted(di.keys())]
方法5:按值排序

def sort_by_value(d): 

items=d.items()

backitems=[[v[1],v[0]] for v in items]

backitems.sort()

return [ backitems[i][1] for i in range(0,len(backitems))]

方法6:按值排序

[ v for v in sorted(di.values())]
方法8:用sorted函式的key= 引數排序:

按照key排序

print sorted(dict1.items(), key=lambda d: d[0])
按照value排序

print sorted(dict1.items(), key=lambda d: d[1])
python內建sorted函式的幫助文件:

sorted(…)

sorted(iterable, cmp=none, key=none, reverse=false) –> new sorted list

dictionary排序的方法,其實它們的核心思想都一樣,即把dictionary中的元素分離出來放到乙個list中,對list排序,從而間接實現對dictionary的排序。這個「元素」可以是key,value或者item。

方法9:python的collection系列-有序字典(ordereddict)

orderddict是對字典型別的補充,它保留了字典元素新增的順序

import collections

dic = collections.ordereddict()

dic["featurename"] = "f1"

dic["uid"] = "12345"

dic["value"] = "7"

print dic

#結果#ordereddict([('featurename', 'f1'), ('uid', '12345'), ('value', '7')])

參考:

python實現字典排序 python 字典排序

引子 字典,形如 dic 字典中的元素沒有順序,所以dic 0 是有語法錯誤的。並且不可以有重複的鍵值,所以 dic.add c 4後,字典變成 待解決問題 如何根據需要可以根據 鍵 或 鍵值 進行不同順序的排序?函式原型 sorted dic,value,reverse dic為比較函式,valu...

python字典排序

1 準備知識 在python裡,字典dictionary是內建的資料型別,是個無序的儲存結構,每一元素是key value對 如 dict 其中 username 和 database 是key,而 password 和 master 是value,可以通過d key 獲得對應值value的引用,但...

python 字典排序

prices 對於這樣乙個字典,如何根據 來對字典進行排序呢?首先你就會問,python中的字典明明是無序的,何談排序之說?別急,辦法總是有的。對於這樣乙個字典的排序,直接使用sorted函式肯定是不行的,因為其排序依據是根據keys而非values。若想對它字典進行排序,首先要做的就是將鍵值對反轉...