平常學(xué)習(xí)了字典(dict)考婴,感覺(jué)還行。但一到用的時(shí)候催烘,就感覺(jué)模棱兩可沥阱。
于是就總結(jié)了字典的常見(jiàn)用法,以后可熟記于心伊群。
- - - - - - - - - - - - - - -
更新日記:2019-05-21
通一表述:字典有兩個(gè)參數(shù)考杉,key, value,下面所描述舰始,鍵:key崇棠,值:value
歡迎批評(píng)指正!
- - - - - - - - - - - - - - - -? ? ? ? 下面是正文? -- - - -- - - -- - -? - - - - - -- -
創(chuàng)建一個(gè)字典
dict1={'a':2,'b':3,'c':8,'d':4}
1丸卷、分別取鍵枕稀、值
取字典的所有鍵,所有的值及老,利用dict1.keys()抽莱,dict1.vaules(),
由于鍵骄恶,值有很多個(gè)食铐,所以要加s,另外注意這里要加括號(hào)僧鲁,這樣的小細(xì)節(jié)不注意虐呻,很容易犯錯(cuò)。
print(dict1.values(),dict1.keys())
結(jié)果:
dict_values([4, 2, 8, 3]) dict_keys(['d', 'a', 'c', 'b'])
可以看出寞秃,返回的是列表的形式
2斟叼、同時(shí)取鍵、值
同時(shí)取字典的鍵春寿、值朗涩,dict1.items(),這里同樣加s和括號(hào)
print(dict1.items())
結(jié)果:
dict_items([('d', 4), ('a', 2), ('c', 8), ('b', 3)])
可以看出绑改,返回的結(jié)果是元組組成的列表
也就是說(shuō)谢床,通過(guò)dict1.items()這個(gè)函數(shù)兄一,把字典形式的鍵、值识腿,存在了一個(gè)元組內(nèi)出革。
3、排序
3.1 sorted
先看一下渡讼,直接用sorted()排序的情況骂束。
dict1={'a':2,'e':3,'f':8,'d':4}
dict2 = sorted(dict1)
print(dict2)
結(jié)果:
['a', 'd', 'e', 'f']
sorted()默認(rèn)是對(duì)字典的鍵,從小到大進(jìn)行排序
3.2 成箫、對(duì)鍵反向排序
對(duì)鍵進(jìn)行反向(從大到姓瓜洹)排序
dict1={'a':2,'e':3,'f':8,'d':4}
dict2 = sorted(dict1,reverse=True)
print(dict2)
結(jié)果:['f', 'e', 'd', 'a']
像這種對(duì)鍵進(jìn)行排序,往往是為了得到 值(value)
拿到鍵最大伟众,對(duì)應(yīng)的值析藕,如:
print(dict1[dict2[0]])#結(jié)果為8
當(dāng)然我們也可以先拿到所有的key召廷,然后再對(duì)key排序
dict1={'a':2,'e':3,'f':8,'d':4}
list1= sorted(dict1.keys(),reverse=True)
print(list1)? ? # 結(jié)果:['f', 'e', 'd', 'a']
3.3凳厢、對(duì)值排序
同樣,用dict1.values()得到所有的values竞慢,然后對(duì)value排序
dict1={'a':2,'e':3,'f':8,'d':4}
list1= sorted(dict1.values())
print(list1)? ? #結(jié)果:[2, 3, 4, 8]
設(shè)值reverse=True 進(jìn)行反向排序
也可以用dict1.items()先紫,得到包含key,value的元組
由于迭代對(duì)象是元組筹煮,返回值自然是元組組成的列表
這里對(duì)排序的規(guī)則進(jìn)行了定義遮精,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)
結(jié)果:
[('a', 2), ('e', 3), ('d', 4), ('f', 8)]
對(duì)鍵進(jìn)行排序:
dict1={'a':2,'e':3,'f':8,'d':4}
list1= sorted(dict1.items(),key=lambda x:x[0])
print(list1)
結(jié)果:
[('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))
結(jié)果:
[('c', 12), ('b', 4), ('a', 8)]
[('c', 12), ('a', 8), ('b', 4)]
itemgetter(0)本冲,獲取key
itemgetter(1),獲取value
5 字典組成的列表排序
數(shù)據(jù)類(lèi)型是列表劫扒,元素是字典檬洞,要求根據(jù)字典的value排序
假設(shè)這樣一個(gè)場(chǎng)景,用戶(hù)user_id沟饥,買(mǎi)商品goods_id添怔,對(duì)商品的評(píng)分是score,要按評(píng)分進(jìn)行逆序排序
dic = [{"goods_id":3,"user_id":11, "score":0.8},
? ? ? {"goods_id":1,"user_id":22, "score":0.1},
? ? ? {"goods_id":2,"user_id":33, "score":0.5}]
sorted(dic, key=lambda x:x['score'], reverse=True)
結(jié)果
[{'goods_id': 3, 'user_id': 11, 'score': 0.8},
{'goods_id': 2, 'user_id': 33, 'score': 0.5},
{'goods_id': 1, 'user_id': 22, 'score': 0.1}]