我怎么能把字典的列表像[{a: 1}, {b: 2}, {' c ': 1}, {' d ': 2}],成一个单一的dict像{“a”:1、“b”:2,“c”:1、“d”:2}?
这里的答案将覆盖两个输入字典之间匹配的键,因为字典不能有重复的键。如果要从匹配的键收集多个值,请参见如何合并字典,从匹配的键收集值。
我怎么能把字典的列表像[{a: 1}, {b: 2}, {' c ': 1}, {' d ': 2}],成一个单一的dict像{“a”:1、“b”:2,“c”:1、“d”:2}?
这里的答案将覆盖两个输入字典之间匹配的键,因为字典不能有重复的键。如果要从匹配的键收集多个值,请参见如何合并字典,从匹配的键收集值。
当前回答
这适用于任何长度的字典:
>>> result = {}
>>> for d in L:
... result.update(d)
...
>>> result
{'a':1,'c':1,'b':2,'d':2}
作为一种理解:
# Python >= 2.7
{k: v for d in L for k, v in d.items()}
# Python < 2.7
dict(pair for d in L for pair in d.items())
其他回答
>>> dictlist = [{'a':1},{'b':2},{'c':1},{'d':2, 'e':3}]
>>> dict(kv for d in dictlist for kv in d.iteritems())
{'a': 1, 'c': 1, 'b': 2, 'e': 3, 'd': 2}
>>>
注意,我向最后一个字典添加了第二个键/值对,以显示它适用于多个条目。 此外,列表中后面字典中的键将覆盖来自较早字典的相同键。
@dietbuddha回答从PEP 448字典解包略有改进,对我来说,这样更可读,而且也更快:
from functools import reduce
result_dict = reduce(lambda a, b: {**a, **b}, list_of_dicts)
但是请记住,这只适用于Python 3.5+版本。
这适用于任何长度的字典:
>>> result = {}
>>> for d in L:
... result.update(d)
...
>>> result
{'a':1,'c':1,'b':2,'d':2}
作为一种理解:
# Python >= 2.7
{k: v for d in L for k, v in d.items()}
# Python < 2.7
dict(pair for d in L for pair in d.items())
如果你不再需要单例字典:
>>> L = [{'a':1}, {'b':2}, {'c':1}, {'d':2}]
>>> dict(map(dict.popitem, L))
{'a': 1, 'b': 2, 'c': 1, 'd': 2}
对于平面字典,你可以这样做:
from functools import reduce
reduce(lambda a, b: dict(a, **b), list_of_dicts)