W3Cschool
恭喜您成為首批注冊用戶
獲得88經(jīng)驗值獎勵
怎樣實現(xiàn)一個鍵對應多個值的字典(也叫 multidict
)?
一個字典就是一個鍵對應一個單值的映射。如果你想要一個鍵映射多個值,那么你就需要將這多個值放到另外的容器中,比如列表或者集合里面。比如,你可以像下面這樣構造這樣的字典:
d = {
'a' : [1, 2, 3],
'b' : [4, 5]
}
e = {
'a' : {1, 2, 3},
'b' : {4, 5}
}
選擇使用列表還是集合取決于你的實際需求。如果你想保持元素的插入順序就應該使用列表,如果想去掉重復元素就使用集合(并且不關心元素的順序問題)。
你可以很方便的使用collections模塊中的defaultdict來構造這樣的字典。defaultdict的一個特征是它會自動初始化每個key剛開始對應的值,所以你只需要關注添加元素操作了。比如:
from collections import defaultdict
d = defaultdict(list)
d['a'].append(1)
d['a'].append(2)
d['b'].append(4)
d = defaultdict(set)
d['a'].add(1)
d['a'].add(2)
d['b'].add(4)
需要注意的是,defaultdict會自動為將要訪問的鍵(就算目前字典中并不存在這樣的鍵)創(chuàng)建映射實體。如果你并不需要這樣的特性,你可以在一個普通的字典上使用setdefault()方法來代替。比如:
d = {} # A regular dictionary
d.setdefault('a', []).append(1)
d.setdefault('a', []).append(2)
d.setdefault('b', []).append(4)
但是很多程序員覺得setdefault()用起來有點別扭。因為每次調(diào)用都得創(chuàng)建一個新的初始值的實例(例子程序中的空列表[])。
一般來講,創(chuàng)建一個多值映射字典是很簡單的。但是,如果你選擇自己實現(xiàn)的話,那么對于值的初始化可能會有點麻煩,你可能會像下面這樣來實現(xiàn):
d = {}
for key, value in pairs:
if key not in d:
d[key] = []
d[key].append(value)
如果使用defaultdict的話代碼就更加簡潔了:
d = defaultdict(list)
for key, value in pairs:
d[key].append(value)
這一小節(jié)所討論的問題跟數(shù)據(jù)處理中的記錄歸類問題有大的關聯(lián)??梢詤⒖?.15小節(jié)的例子。
Copyright©2021 w3cschool編程獅|閩ICP備15016281號-3|閩公網(wǎng)安備35020302033924號
違法和不良信息舉報電話:173-0602-2364|舉報郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號
聯(lián)系方式:
更多建議: