我想在不覆盖的情况下更新python字典。
就像是这样:
d1 = {id1 : val1, id2 : val2}
d2 = {id1 : val3, id3 : val4}
d1 + d2 = {id1 : [val1, val3], id2 : [val2], id3 : [val4]}
您有什么想法吗?
答案 0 :(得分:0)
听起来像您需要一个函数,该函数为每个键创建新列表,然后在必要时附加到它们。
d1 = {'id1' : 'val1', 'id2' : 'val2'}
d2 = {'id1' : 'val3', 'id3' : 'val4'}
def concatDicts(d1,d2):
dsum = {}
for key in d1:
if key not in dsum:
dsum[key] = [d1[key]]
for key in d2:
if key not in dsum:
dsum[key] = []
dsum[key].append(d2[key])
return dsum
d3 = concatDicts(d1,d2)
print(d3)
# d3 = {id1 : [val1, val3], id2 : [val2], id3 : [val4]}