創建一個字典
dict1={'a':2,'b':3,'c':8,'d':4}
1、分別取鍵、值
取字典的所有鍵,所有的值,利用dict1.keys(),dict1.vaules(),
由於鍵,值有很多個,所以要加s,另外注意這里要加括號,這樣的小細節不注意,很容易犯錯。
print(dict1.values(),dict1.keys())
結果:
dict_values([4, 2, 8, 3]) dict_keys(['d', 'a', 'c', 'b'])
可以看出,返回的是列表的形式
2、同時取鍵、值
同時取字典的鍵、值,dict1.items(),這里同樣加s和括號
print(dict1.items())
結果:
dict_items([('d', 4), ('a', 2), ('c', 8), ('b', 3)])
可以看出,返回的結果是元組組成的列表
也就是說,通過dict1.items()這個函數,把字典形式的鍵、值,存在了一個元組內。
3、排序
3.1 sorted
先看一下,直接用sorted()排序的情況。
dict1={'a':2,'e':3,'f':8,'d':4}
dict2 = sorted(dict1)
print(dict2)
結果:
['a', 'd', 'e', 'f']
sorted()默認是對字典的鍵,從小到大進行排序
3.2 、對鍵反向排序
對鍵進行反向(從大到小)排序
dict1={'a':2,'e':3,'f':8,'d':4}
dict2 = sorted(dict1,reverse=True)
print(dict2)
結果:['f', 'e', 'd', 'a']
像這種對鍵進行排序,往往是為了得到 值(value)
拿到鍵最大,對應的值,如:
print(dict1[dict2[0]])#結果為8
當然我們也可以先拿到所有的key,然后再對key排序
dict1={'a':2,'e':3,'f':8,'d':4}
list1= sorted(dict1.keys(),reverse=True)
print(list1) # 結果:['f', 'e', 'd', 'a']
3.3、對值排序
同樣,用dict1.values()得到所有的values,然后對value排序
dict1={'a':2,'e':3,'f':8,'d':4}
list1= sorted(dict1.values())
print(list1) #結果:[2, 3, 4, 8]
設值reverse=True 進行反向排序
也可以用dict1.items(),得到包含鍵,值的元組
由於迭代對象是元組,返回值自然是元組組成的列表
這里對排序的規則進行了定義,x指元組,x[1]是值,x[0]是鍵
dict1={'a':2,'e':3,'f':8,'d':4}
list1= sorted(dict1.items(),key=lambda x:x[1])
print(list1)
結果:
[('a', 2), ('e', 3), ('d', 4), ('f', 8)]
對鍵進行排序:
dict1={'a':2,'e':3,'f':8,'d':4}
list1= sorted(dict1.items(),key=lambda x:x[0])
print(list1)
結果:
[('a', 2), ('d', 4), ('e', 3), ('f', 8)]
4 itemgetter
from operator import itemgetter
d = {"a":8,"b":4,"c":12}
print(sorted(d.items(),key=itemgetter(0),reverse=True))
print(sorted(d.items(),key=itemgetter(1),reverse=True))
結果:
[('c', 12), ('b', 4), ('a', 8)]
[('c', 12), ('a', 8), ('b', 4)]
itemgetter(0),獲取key
itemgetter(1),獲取value
---------------------
轉自原文:https://blog.csdn.net/ustbbsy/article/details/79637594