python怎么合并两个字典
Python中将两个字典进行合并操作,是一个比较常见的问题。本文将介绍几种实现两个字典合并的方案,并对其进行比较。
对于这个问题,比较直观的想法是将两个字典做相加操作,赋值给结果字典,其代码为:
python两个字典合并(方法1)
dictMerged1 = dict( dict1.items() + dict2.items() )
然而,该方法合并时所用时间较长,效率更高的代码为:
python两个字典合并(方法2)
dictMerged2 = dict( dict1, **dict2 )
这种方法使用的是dict()工厂方法(Python2.2以上版本)。如果输入参数是另一个字典(此处为dict1),则调用该工厂方法时会从dict1中复制内容生成新的字典。该工厂方法从Python2.3版本开始,允许接受字典或关键字参数字典进行调用。
但应当注意,对于这种调用方式,dict()最多只接受一个参数(或者说是一组name=value的可变长参数),而不会再接受另一个字典。因此直观上的简单使用dict1与dict2两个参数的方法会提示如下错误:
>>> 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()操作:
python两个字典合并(方法3)
dictMerged3 = dict1.copy() dictMerged3.update( dict2 )
对于第一步的复制操作而言,这种使用内建方法copy()的复制方式,和方法2中的复制结果是一样的,但根据《Core Python Programming (2nd edition)》一书中7.3.2节所述,从已存在字典中生成新字典的方式dictNew = dict( dictOld )较内建方法dictNew = dictOld.copy()会慢一些,因此书中推荐使用copy()方法。
因此,从这几种方式看来,方法3的效率最高,并且代码也比较易读。
相关推荐:《Python教程》
以上就是python怎么合并两个字典的详细内容,更多请关注其它相关文章!
上一篇: python类变量和实例变量的区别
下一篇: python的库有多少个?