python字典合并几种方式对比,Python合并两个字典的常用方法与效率比较

本文实例讲述了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方法。

希望本文所述对大家的Python程序设计有所帮助。

总结

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值