Python實(shí)現(xiàn)字典序列ChainMap
容器數(shù)據(jù)類(lèi)型包括數(shù)組list,字典dict以及元組tuple等。本篇,將詳細(xì)介紹ChainMap字典序列的使用。
ChainMapChainMap類(lèi)管理的是一個(gè)字典序列,并按其出現(xiàn)的順序搜索以查找與鍵關(guān)聯(lián)的值。ChainMap提供了一個(gè)很好的“上下文”容器,因此可以把它看成一個(gè)棧,棧增長(zhǎng)時(shí)發(fā)生變更,棧收縮時(shí)這些變更被丟棄。
下面,我們來(lái)看看其基本的使用規(guī)則:
import collectionsa = {'a': 'A', 'c': 'c', }b = {'b': 'B', 'c': 'D', }col = collections.ChainMap(a, b)# 和普通字典一樣訪(fǎng)問(wèn)print(col['a'])print(list(col.keys()), list(col.values()))for key, value in col.items(): print(key, value)
運(yùn)行之后,效果如下:
可以看到,在相同的key值情況下,只有子映射a的值。這也就是說(shuō)明ChainMap是按子映射傳遞到構(gòu)造函數(shù)的順序來(lái)搜索這些子映射。
重排列其實(shí),這種子映射的順序在maps屬性中,我們直接通過(guò)它增加新映射,或者改變映射的順序。比如上面映射c是取的a字典中的值,那么我們直接顛倒順序,就可以取b的值。
import collectionsa = {'a': 'A', 'c': 'c', }b = {'b': 'B', 'c': 'D', }col = collections.ChainMap(a, b)#顛倒順序col.maps = list(reversed(col.maps))for key, value in col.items(): print(key, value)
運(yùn)行之后,效果如下:
這里函數(shù)reversed()很好理解,就是顛倒英文的意思。
更新值ChainMap歸并子映射的值,應(yīng)該如何更改呢?其實(shí)不管你是直接更新基本的子映射值,還是更新ChainMap對(duì)象的值。都會(huì)將子映射與ChainMap對(duì)象的值同時(shí)改變。
import collectionsa = {'a': 'A', 'c': 'c', }b = {'b': 'B', 'c': 'D', }col = collections.ChainMap(a, b)col[’c’] = ’Z’print(col[’c’])#變更回來(lái)col[’c’] = ’c’a[’c’] = ’Z’print(col[’c’])
運(yùn)行之后,效果如下:
那么如果保證不更改掉原理的底層的數(shù)據(jù)結(jié)構(gòu)呢?答案是通過(guò)new_child()創(chuàng)建一個(gè)新的ChainMap。具體代碼如下:
import collectionsa = {'a': 'A', 'c': 'c', }b = {'b': 'B', 'c': 'D', }col = collections.ChainMap(a, b)col2 = col.new_child()print(col)print(col2)print('--------------------------')col2[’c’] = ’Z’print(col)print(col2)
運(yùn)行之后,效果如下:
可以看到,new_child()提供了一個(gè)額外的映射在最前面。正是這種基于堆棧的思維,我們很容易在一次迭代中增加或更新值,然后在下一次迭代中丟棄這些改變。
到此這篇關(guān)于Python實(shí)現(xiàn)字典序列ChainMap的文章就介紹到這了,更多相關(guān)Python 字典序列ChainMap內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. 如何在.net6webapi中使用自動(dòng)依賴(lài)注入2. VUE使用ElementUI下拉框 @change事件數(shù)據(jù)不回顯問(wèn)題3. Python如何對(duì)XML 解析4. 5個(gè)HTML5的常用本地存儲(chǔ)方式詳解與介紹5. vue頁(yè)面設(shè)置滾動(dòng)失敗的完美解決方案(scrollTop一直為0)6. 使用JSP實(shí)現(xiàn)簡(jiǎn)單的用戶(hù)登錄注冊(cè)頁(yè)面示例代碼解析7. ASP.NET MVC使用Boostrap實(shí)現(xiàn)產(chǎn)品展示、查詢(xún)、排序、分頁(yè)8. Ajax實(shí)現(xiàn)頁(yè)面無(wú)刷新留言效果9. 《CSS3實(shí)戰(zhàn)》筆記--漸變?cè)O(shè)計(jì)(二)10. JSP中out對(duì)象的實(shí)例詳解
