我怎么能把字典的列表像[{a: 1}, {b: 2}, {' c ': 1}, {' d ': 2}],成一个单一的dict像{“a”:1、“b”:2,“c”:1、“d”:2}?


这里的答案将覆盖两个输入字典之间匹配的键,因为字典不能有重复的键。如果要从匹配的键收集多个值,请参见如何合并字典,从匹配的键收集值。


当前回答

>>> 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}
>>>

注意,我向最后一个字典添加了第二个键/值对,以显示它适用于多个条目。 此外,列表中后面字典中的键将覆盖来自较早字典的相同键。

其他回答

在Python 3.3+的情况下,有一个ChainMap集合:

>>> from collections import ChainMap
>>> a = [{'a':1},{'b':2},{'c':1},{'d':2}]
>>> dict(ChainMap(*a))
{'b': 2, 'c': 1, 'a': 1, 'd': 2}

还看到:

collections.ChainMap的目的是什么?

dict1.update( dict2 )

这是不对称的,因为你需要选择如何处理重复的键;在本例中,dict2将覆盖dict1。换另一种方式。

编辑:啊,抱歉,没看到。

这可以在一个表达式中实现:

>>> from itertools import chain
>>> dict( chain( *map( dict.items, theDicts ) ) )
{'a': 1, 'c': 1, 'b': 2, 'd': 2}

这最后一件事不怪我!

然而,我认为用一个简单的for循环来实现这一点可能更符合python(显式>隐式,扁平>嵌套)。YMMV。

>>> L=[{'a': 1}, {'b': 2}, {'c': 1}, {'d': 2}]    
>>> dict(i.items()[0] for i in L)
{'a': 1, 'c': 1, 'b': 2, 'd': 2}

注意:'b'和'c'的顺序与输出不匹配,因为字典是无序的

如果字典可以有多个键/值

>>> dict(j for i in L for j in i.items())

你可以使用函数库中的join函数:

from funcy import join
join(list_of_dicts)

对于平面字典,你可以这样做:

from functools import reduce
reduce(lambda a, b: dict(a, **b), list_of_dicts)