這篇文章主要講解了“python怎么反轉(zhuǎn)字典”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來(lái)研究和學(xué)習(xí)“python怎么反轉(zhuǎn)字典”吧!
創(chuàng)新互聯(lián)建站專注于漣源企業(yè)網(wǎng)站建設(shè),成都響應(yīng)式網(wǎng)站建設(shè),商城網(wǎng)站建設(shè)。漣源網(wǎng)站建設(shè)公司,為漣源等地區(qū)提供建站服務(wù)。全流程按需制作網(wǎng)站,專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,創(chuàng)新互聯(lián)建站專業(yè)和態(tài)度為您提供的服務(wù)
在某些特定的場(chǎng)景,你會(huì)遇到這樣的需求,將字典的 key 和 value 進(jìn)行互換,例如:
d = { 'a': 1, 'b':2 }
變成
d = { 1: 'a', 2: 'b' }
你可能最先能想到的土辦法就是遍歷字典,逐個(gè)將 key-value 互換成 value-key 放進(jìn)新字典中
d = {'a': 1, 'b': 2}
new_d = dict()
for key in d:
value = d[key]
new_d[value] = key
其實(shí)啊,如果你知道推導(dǎo)式概念的話,那么用一行代碼就可以搞定。自從 Python2.7和 Python3 加入了列表推導(dǎo)式、集合推導(dǎo)式和字典推導(dǎo)式之后,解決這類問(wèn)題就得心應(yīng)手了。用字典推導(dǎo)式可優(yōu)雅寫(xiě)出:
new_d = {v: k for k, v in d.items()}
如果你熟悉列表推導(dǎo)式,上面的代碼你也覺(jué)得很眼熟,就是將 key,value 互換構(gòu)成新的字典。也有人可能會(huì)推薦你使用函數(shù)式編程風(fēng)格的代碼來(lái)實(shí)現(xiàn):
>>> d = { 'a': 1, 'b':2 }
>>> dict((map(reversed, d.items())))
{1: 'a', 2: 'b'}
函數(shù)式編程風(fēng)格的代碼看起來(lái)可讀性并沒(méi)有那么好,而且效率上也比不上推導(dǎo)式,我們可以用 timeit 證實(shí)一下
>>> import timeit
>>> timeit.timeit("dict((map(reversed, {'a': 1, 'b': 2}.items())))", number=100000)
0.16313515009824187
>>> timeit.timeit("{v: k for k, v in {'a': 1, 'b': 2}.items()}", number=100000)
0.06065327790565789
一看速度上慢將近 3 倍,自從 Python 引入了推導(dǎo)式特性后, map、filter、reduce 這樣的函數(shù)就很少被推薦使用了。
在來(lái)思考一個(gè)問(wèn)題,為什么字典自己沒(méi)有提供這樣的 API 接口給我們使用?
根據(jù)字典的特性:
字典的 key 必須是唯一的,相同的 key 會(huì)被覆蓋, 而 value 可以相同,所以這個(gè)反轉(zhuǎn),就是 key 和 value 都是唯一的場(chǎng)景下。
key 必須是可 hash 的,所以如果 value 是不可 hash 的對(duì)象,比如列表,就不能做為 key 了。
因此字典反轉(zhuǎn)只適合某些特定場(chǎng)景,而不適合當(dāng)做一個(gè)通用操作來(lái)使用,所以字典的API里面也就不會(huì)提供這樣的操作了。
感謝各位的閱讀,以上就是“python怎么反轉(zhuǎn)字典”的內(nèi)容了,經(jīng)過(guò)本文的學(xué)習(xí)后,相信大家對(duì)python怎么反轉(zhuǎn)字典這一問(wèn)題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!