Python如何合并多个字典或映射


Posted in Python onJuly 24, 2020

问题

现在有多个字典或者映射,你想将它们从逻辑上合并为一个单一的映射后执行某些操作,比如查找值或者检查某些键是否存在。

解决方案

加入你有如下两个字典:

a = {'x': 1, 'z': 3 }
b = {'y': 2, 'z': 4 }

现在假设你必须在两个字典中执行查找操作(比如先从a中找,如果找不到再在b中找)。一个非常简单扼解决方案就是使用collections模块中的ChainMap类。比如:

from collections import ChainMap
c = ChainMap(a,b)
print(c['x']) # Outputs 1 (from a)
print(c['y']) # Outputs 2 (from b)
print(c['z']) # Outputs 3 (from a)

讨论

一个ChainMap接受多个字典并将它们在逻辑上变为一个字典。然后,这些字典并不是真的合并在一起了,ChainMap类只是在内部创建了一个容纳这些字典的列表并重新定义了一些常见的字典操作来遍历这个列表。大部分字典操作都是可以正常使用的,比如:

>>> len(c)
3
>>> list(c.keys())
['x', 'y', 'z']
>>> list(c.values())
[1, 2, 3]
>>>

如果出现重复键,那么第一次出现的映射值会被返回。因此,例子程序中的c[‘z']总是会返回字典a中对应的值,而不是b中对应的值。

对于字典的更新或删除操作总是影响的是列表中第一个字典。比如:

>>> c['z'] = 10
>>> c['w'] = 40
>>> del c['x']
>>> a
{'w': 40, 'z': 10}
>>> del c['y']
Traceback (most recent call last):
...
KeyError: "Key not found in the first mapping: 'y'"
>>>

ChainMap对于编程语言中的作用范围变量(比如globals, locals等)是非常有用的。事实上,有一些方法可以使它变得简单:

>>> values = ChainMap()
>>> values['x'] = 1
>>> # Add a new mapping
>>> values = values.new_child()
>>> values['x'] = 2
>>> # Add a new mapping
>>> values = values.new_child()
>>> values['x'] = 3
>>> values
ChainMap({'x': 3}, {'x': 2}, {'x': 1})
>>> values['x']
3
>>> # Discard last mapping
>>> values = values.parents
>>> values['x']
2
>>> # Discard last mapping
>>> values = values.parents
>>> values['x']
1
>>> values
ChainMap({'x': 1})
>>>

作为ChainMap的替代,你可能会考虑使用update()方法将两个字典合并。比如:

>>> a = {'x': 1, 'z': 3 }
>>> b = {'y': 2, 'z': 4 }
>>> merged = dict(b)
>>> merged.update(a)
>>> merged['x']
1
>>> merged['y']
2
>>> merged['z']
3
>>>

这样也能行得通,但是它需要你创建一个完全不同的字典对象(或者是破坏现有字典结构)。同时,如果原字典做了更新,这种改变不会反应到新的合并字典中去。比如:

>>> a['x'] = 13
>>> merged['x']
1

ChianMap使用原来的字典,它自己不创建新的字典。所以它并不会产生上面所说的结果,比如:

>>> a = {'x': 1, 'z': 3 }
>>> b = {'y': 2, 'z': 4 }
>>> merged = ChainMap(a, b)
>>> merged['x']
1
>>> a['x'] = 42
>>> merged['x'] # Notice change to merged dicts
42
>>>

以上就是Python如何合并多个字典或映射的详细内容,更多关于Python 合并字典或映射的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
WxPython建立批量录入框窗口
Feb 27 Python
python处理大日志文件
Jul 23 Python
python用WxPython库实现无边框窗体和透明窗体实现方法详解
Feb 21 Python
Pycharm如何导入python文件及解决报错问题
May 10 Python
Python发送邮件实现基础解析
Aug 14 Python
python中温度单位转换的实例方法
Dec 27 Python
python基于Kivy写一个图形桌面时钟程序
Jan 28 Python
用python制作个音乐下载器
Jan 30 Python
Python Socket编程详解
Apr 25 Python
Python 如何实现文件自动去重
Jun 02 Python
Python预测分词的实现
Jun 18 Python
python​格式化字符串
Apr 20 Python
Matplotlib 绘制饼图解决文字重叠的方法
Jul 24 #Python
Python3.7安装pyaudio教程解析
Jul 24 #Python
python调用私有属性的方法总结
Jul 24 #Python
python中取绝对值简单方法总结
Jul 24 #Python
python代码能做成软件吗
Jul 24 #Python
深入了解Python 变量作用域
Jul 24 #Python
详解Python IO编程
Jul 24 #Python
You might like
DOM XPATH获取img src值的query
2013/09/23 PHP
PHP中的排序函数sort、asort、rsort、krsort、ksort区别分析
2014/08/18 PHP
php实现网站顶踩功能的完整前端代码
2015/07/19 PHP
Yii2.0实现的批量更新及批量插入功能示例
2019/01/29 PHP
PHP实现数据四舍五入的方法小结【4种方法】
2019/03/27 PHP
在laravel-admin中列表中禁止某行编辑、删除的方法
2019/10/03 PHP
jQuery EasyUI API 中文文档 - ProgressBar 进度条
2011/09/29 Javascript
Jquery Uploadify多文件上传带进度条且传递自己的参数
2013/08/28 Javascript
jquery实现多级下拉菜单的实例代码
2013/10/02 Javascript
不同Jquery版本引发的问题解决
2013/10/14 Javascript
学习JavaScript设计模式之享元模式
2016/01/18 Javascript
原生js仿jquery实现对Ajax的封装
2016/10/04 Javascript
微信小程序实战之运维小项目
2017/01/17 Javascript
Bootstrap里的文件分别代表什么意思及其引用方法
2017/05/01 Javascript
jQuery除指定区域外点击任何地方隐藏DIV功能
2017/11/13 jQuery
详解vue表单——小白速看
2018/04/08 Javascript
浅谈Vue render函数在ElementUi中的应用
2018/09/06 Javascript
BootStrap modal实现拖拽功能
2018/12/01 Javascript
详解Python 实现元胞自动机中的生命游戏(Game of life)
2018/01/27 Python
Python实现通过继承覆盖方法示例
2018/07/02 Python
对python调用RPC接口的实例详解
2019/01/03 Python
Python3 tkinter 实现文件读取及保存功能
2019/09/12 Python
使用python实现飞机大战游戏
2020/03/23 Python
TensorFlow-gpu和opencv安装详细教程
2020/06/30 Python
python调用摄像头的示例代码
2020/09/28 Python
Hertz荷兰:荷兰和全球租车
2018/01/07 全球购物
信息系统专业个人求职信范文
2013/12/07 职场文书
节能减耗标语
2014/06/21 职场文书
公司离职证明范本(5篇)
2014/09/17 职场文书
预备党员群众路线思想汇报2014
2014/10/25 职场文书
英语邀请函范文
2015/02/02 职场文书
最感人的道歉情书
2015/05/12 职场文书
食堂卫生管理制度
2015/08/04 职场文书
2016公司新年问候语
2015/11/11 职场文书
《月球之谜》教学反思
2016/02/20 职场文书
SQLServer2019 数据库的基本使用之图形化界面操作的实现
2021/04/08 SQL Server