在python裡,字典dictionary是內建的資料型,是個無序的儲存結構,每個元素是key-value對。
如:dict = {'username':'xiaoming','password':'123456'},其中'username'和'password'是key,而' xiaoming'和'123456'是value,可以透過d[key]得到對應值value的引用,但是不能透過value得到key。
對於dictionnary,需知道以下幾點注意事項:
a、dictionary 的key 是大小寫敏感的;
b、一個dictionary中不能有重複的key;
c、 dictionary是無序的,沒有元素順序的概念,它們只是序偶的簡單排列。
字典按鍵/值進行排序:
#dictionary本身沒有順序概念,但是總是在某些時候,但是我們常常需要對字典進行排序
方法1:依照key值排序。
def sortedDictValues1(adict): items = adict.items() print "items:",items items.sort() return [value for key, value in items] adict = {"a1":11,"b1":2,"c1":30,"e1":20,"d1":4} 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))]
先把item的key和value交換位置放入一個list中,再根據list每個元素的第一個值,即原來的value值,排序:
方法6:依值排序
[ v for v in sorted(di.values())]
方法7:用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。
方法8: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字典可以排序嗎的詳細內容。更多資訊請關注PHP中文網其他相關文章!