Python基础——字典中由value查key的几点说明
眾所周知,字典dict最大的好處就是查找或插入的速度極快,并且不想列表list一樣,隨著key的增加越來越復(fù)雜。但是dict需要占用較大的內(nèi)存空間,換句話說,字典dict是以空間換速度。詳細(xì)請(qǐng)見如下示例:
#------------------------------------------------------------------------------------
student = {'小萌': '1001', '小智': '1002', '小強(qiáng)': '1003', '小明': '1004'}
#------------------------------------------------------------------------------------
由key查value很簡(jiǎn)單,直接調(diào)用:dict ['key'],如下:
#-----------------------------------------------------------------------------------
>>> student ['小強(qiáng)']
結(jié)果顯示:'1003'
#-----------------------------------------------------------------------------------
但如果此時(shí),我們想由value查找key,則會(huì)相對(duì)復(fù)雜一點(diǎn),一般來說可通過如下3種方式實(shí)現(xiàn):
#-----------------------------------------------------------------------------------
A. 充分利用 keys() 、values()、index() 函數(shù)
>>> list (student.keys()) [list (student.values()).index ('1004')]
結(jié)果顯示: '小明'
#-----------------------------------------------------------------------------------
B. 通過定義get_key函數(shù)的方式
>>> def get_key (dict, value):
?????????????? return [k for k, v in dict.items() if v == value]
>>> get_key (student, '1002')
結(jié)果顯示:'小智'
#-----------------------------------------------------------------------------------
C. 將原字典dict進(jìn)行反轉(zhuǎn)得新字典new_dict,由原來的K-V存儲(chǔ)形式,變?yōu)閂-K存儲(chǔ)形式
>>> new_dict = {v : k for k, v in dict.items()}
>>> new_dict ['1001']
結(jié)果顯示:'小萌'
#-----------------------------------------------------------------------------------
雖然我們可以通過以上方式獲得由value查找key的目的,但是我們必須明確一點(diǎn):在字典dict中,key值是唯一的,且不可變;而value可以隨意取值,且不唯一。之所以強(qiáng)調(diào)這一點(diǎn),是因?yàn)樵诶蒙鲜龇椒〞r(shí),會(huì)出現(xiàn)失效的情況。如下所示:
假設(shè)此時(shí)原字典student發(fā)生了一些變化,變?yōu)?#xff1a;
#-----------------------------------------------------------------------------------
student = {'小萌': '1001', '小智': '1002', '小強(qiáng)': '1003', '小明': ['1004', '1005']}
#-----------------------------------------------------------------------------------
那么再次調(diào)用上述3種方法,由value查key時(shí),則出現(xiàn):
#-----------------------------------------------------------------------------------
>>> list (student.keys()) [list (student.values()).index ('1004')]
結(jié)果顯示:ValueError: '1004' is not in list
因?yàn)関alue不唯一,key—'小明' 對(duì)應(yīng)了兩個(gè)value,且他們以list形式存儲(chǔ)著,所以如果只取其中一個(gè)value值是無法查找對(duì)應(yīng)的key值,必須將多個(gè)value值組成的list視為一個(gè)整體,即:
>>> list (student.keys()) [list (student.values()).index (['1004', '1005'])]
結(jié)果顯示:'小明'
#-----------------------------------------------------------------------------------
>>> def get_key (dict, value):
?????????????? return [k for k, v in dict.items() if v == value]
>>> get_key (student, '1004')
結(jié)果顯示:[ ]
>>> get_key (student, ['1004', '1005'])
結(jié)果顯示:'小明'
#----------------------------------------------------------------------------------->>> new_dict = {v : k for k, v in dict.items()}
回車后系統(tǒng)報(bào)錯(cuò):TypeError: unhashable type: 'list'
由于key不可變且唯一,當(dāng)K-V反轉(zhuǎn)以后,key—'小明' 對(duì)應(yīng)了兩個(gè)value組成的list,反過來就變成了key,即此時(shí)由list充當(dāng)key,因?yàn)閘ist是可變動(dòng)的,所以這在Python中是不允許的。總結(jié)
以上是生活随笔為你收集整理的Python基础——字典中由value查key的几点说明的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 关于c语言中错误error:stray‘
- 下一篇: 改进粒子群算法的配电网故障定位(Pyth