Python 合并两个字典的各种方法以及效率的比较

下面的代码举例了5种合并两个字典的方法,并且做了个简单的性能测试

#!/usr/bin/python  
import time  
  
def f1(d1, d2):  
    return dict(d1, **d2)  
  
def f2(d1, d2):  
    return dict(d1.items() + d2.items())  
  
def f3(d1, d2):  
    d = d1.copy()  
    d.update(d2)  
    return d  
  
def f4(d1, d2):  
    d1.update(d2)  
    return d1  
  
def f5(d1, d2):  
    d = dict(d1)  
    d.update(d2)  
    return d  
      
def f6(d1, d2):  
    return (lambda a, b: (lambda a_copy: a_copy.update(b) or a_copy)(a.copy()))(d1, d2)  
  
def f7(d1, d2):  
    d = {}  
    d.update(d1)  
    d.update(d2)  
    return d  
  
def t(f, n):  
    st = time.time()  
    for i in range(1000000):  
        dic1 = {'a':'AA','b':'BB','c':'CC'}  
        dic2 = {'A':'aa','B':'bb','C':'cc'}  
        f(dic1, dic2)  
    et = time.time()  
    print '%s cost:%s'%(n, et-st)  
  
t(f1, 'f1')  
t(f2, 'f2')  
t(f3, 'f3')  
t(f4, 'f4')  
t(f5, 'f5')  
t(f6, 'f6')  
t(f7, 'f7')

除了f4方法会对字典d1造成破坏性修改之外,另外的几种方法都是把合并的结果作为新的字典返回。

下面是测试结果:

f1 cost:2.382999897  
f2 cost:4.45399999619  
f3 cost:3.02100014687  
f4 cost:1.73000001907  
f5 cost:2.3710000515  
f6 cost:2.89700007439  
f7 cost:2.35600018501  

可以看出f4最为高效,如果不需要保留原字典的话推荐使用f4方法。

原文地址:http://blog.csdn.net/trbbadboy/article/details/18009403

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值