首页 > 编程语言 > 详细

【python cookbook】【数据结构与算法】9.在两个字典中寻找相同点

时间:2016-08-07 18:27:28      阅读:259      评论:0      收藏:0      [点我收藏+]

问题:寻找两个字典中间相同的地方(相同的键、相同的值等)

解决方案:通过keys()或者items()方法来执行常见的集合操作(比如求并集、交集和差集)

技术分享

>>> a={x:1,y:2,z:3}
>>> b={ww:10,x:11,y:2}
>>> a.keys()& b.keys()  #键的交集
{y, x}
>>> a.keys()- b.keys() #键的差集
{z}
>>> a.keys()| b.keys() #键的并集
{ww, y, x, z}
>>> a.items()& b.items() 
{(y, 2)}
>>> a.items()- b.items()
{(z, 3), (x, 1)}
>>> a.items()| b.items()
{(ww, 10), (z, 3), (x, 1), (x, 11), (y, 2)}
>>> 

这些类型的操作也可用来修改或过滤掉字典中的内容。例如:

>>> c = {key:a[key] for key in a.keys()-{w,z}}  #新建一个去掉某些键的新字典
>>> c
{y: 2, x: 1}
>>> 

总结:

字典的keys()方法、items()方法支持集合操作,但是values()方法不支持。因为在字典中从值的角度来看并不能保证所有的值都是唯一的,这会导致某些集合操作存在问题。但是可以通过将值转化为集合来实现此类操作。

 

【python cookbook】【数据结构与算法】9.在两个字典中寻找相同点

原文:http://www.cnblogs.com/apple2016/p/5746626.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!