Python中如何实现两个字典合并
Python中将两个字典进行合并操作,是一个比较常见的问题。本文将介绍几种实现两个字典合并的方案,并对其进行比较。
对于这个问题,比较直观的想法是将两个字典做相加操作,赋值给结果字典,其代码为:
1 |
dictMerged1 = dict( dict1.items() + dict2.items() ) |
然而,该方法合并时所用时间较长,效率更高的代码为:
1 |
dictMerged2 = dict( dict1, **dict2 ) |
这种方法使用的是dict()
工厂方法(Python2.2以上版本)。如果输入参数是另一个字典(此处为dict1),则调用该工厂方法时会从dict1中复制内容生成新的字典。该工厂方法从Python2.3版本开始,允许接受字典或关键字参数字典进行调用。但应当注意,对于这种调用方式,dict()
最多只接受一个参数(或者说是一组name=value
的可变长参数),而不会再接受另一个字典。因此直观上的简单使用dict1与dict2两个参数的方法会提示如下错误:
1 2 3 4 |
>>> dictMerged = dict( dict1, dict2 ) Traceback (most recent call last): File "<stdin>", line 1, in <module> TypeError: dict expected at most 1 arguments, got 2 |
这也就是我们看到上面的方法2中使用的是**dict2的原因。熟悉C的朋友应当注意,在这里*的意思并不代表指针,这是Python中可变长函数参数的写法(关于可变长函数参数的相关知识见本文)。在这里,**的意思是基于字典的可变长函数参数。
方法2执行的是如同下面方法3中的代码,即先将dict1拷贝给dictMerged,在执行update()
操作:
1 2 |
dictMerged3 = dict1.copy() dictMerged3.update( dict2 ) |
对于第一步的复制操作而言,这种使用内建方法copy()
的复制方式,和方法2中的复制结果是一样的,但根据《Core Python Programming (2nd edition)》一书中7.3.2节所述,从已存在字典中生成新字典的方式dictNew = dict( dictOld )
较内建方法dictNew = dictOld.copy()
会慢一些,因此书中推荐使用copy()
方法。
因此,从这几种方式看来,方法3的效率最高,并且代码也比较易读。
本文内容遵从CC3.0版权协议,转载请注明:转自Pythoner
本文链接地址:Python中如何实现两个字典合并
为什么不直接dict1.update( dict2 )
因为要被合并的两个字典还另有他用吧→_→
如果两个字典有重复key,两个字典的顺序就会影响结果。
d1 = {“dev”: {“cpu”: [{“nice”: 1}, {“nice”: 2}, {“nice”: 3}]}}
d2 = {“dev”: {“cpu”: [{“index”: 1}, {“index”: 2}, {“index”: 3}]}}
请问这种怎么merge?
这里给出第4种方法,使用ChainMap库,多个字典合并,还不影响原来的字典使用