python 字典覆盖函数_如何合并N Python字典而不覆盖值?

我有这个词典列表:

list_of_ds = [

{'a': [1, 2], 'b': [4, 5], 'c': [6, 7]},

{'a': [4], 'b': [56], 'c': [46]},

{'a': [92], 'b': [65], 'c': [43]}

]

我希望这个输出:

{'a': [1, 2, 4, 92], 'b': [4, 5, 56, 65], 'c': [6, 7, 46, 43]}

到现在 …

我试过了

d_of_ds = reduce(lambda d1, d2: d1.update(d2), list_of_ds)

give:AttributeError:’NoneType’对象没有属性’update’

我试过了

d_of_ds = reduce(lambda d1, d2: d1.update(d2) or d1, list_of_ds, {})

覆盖每次迭代:{‘a’:[92],’b’:[65],’c’:[43]}

我试过了

d_of_ds = {k: v for d in list_of_ds for k, v in d.items()}

覆盖每次迭代:{‘a’:[92],’b’:[65],’c’:[43]}

解决方法:

在这种情况下使用reduce不是一个好主意.而且你的lambda函数根本就有错误的逻辑,因为你试图一起更新整个字典,而不是它们的元素看到如下:

>>> a={'a':[1,2], 'b':[4,5],'c':[6,7]}

>>> a.update({'a':[4], 'b':[56],'c':[46]})

>>> a

{'a': [4], 'c': [46], 'b': [56]}

但作为一种更有效的方法,您可以使用dict.setdefault方法:

>>> new={}

>>> for d in list_of_ds:

... for i,j in d.items():

... new.setdefault(i,[]).extend(j)

...

>>> new

{'a': [1, 2, 4, 92], 'c': [6, 7, 46, 43], 'b': [4, 5, 56, 65]}

你也可以使用collections.defaultdict:

>>> from collections import defaultdict

>>> d=defaultdict(list)

>>> for sub in list_of_ds:

... for i,j in sub.items():

... d[i].extend(j)

...

>>> d

defaultdict(, {'a': [1, 2, 4, 92], 'c': [6, 7, 46, 43], 'b': [4, 5, 56, 65]})

标签:python,dictionary,merge

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值