-
Chainmap函数的使用
如果需要将多个字典进行合并的话,可以用ChainMap函数进行操作;不过这里要说清楚一点,该函数不是对原数据进行复制,这是指向原数据,相当于一个将数据读取,指向数据存储的内存地址位置,如何原字典进行了修改,那么ChainMap映射同样会进行修改;同理,对ChainMap进行修改,也会对原数据进行修改。
利用ChainMap进行多个字典的合并
# !usr/bin/env python # -*- coding:utf-8 _*- """ @Author:何以解忧 @Blog(个人博客地址): shuopython.com @WeChat Official Account(微信公众号):猿说python @Github:www.github.com @File:python_chainmap.py @Time:2019/11/20 21:25 @Motto:不积跬步无以至千里,不积小流无以成江海,程序人生的精彩需要坚持不懈地积累! """ from collections import ChainMap dict1= {"a":"zhangsan","b":"lisi"} dict2= {"c":"wangwu"} dict3= {"d":"liqui","e":"laowang"} new_dict = ChainMap(dict1,dict2,dict3) print(new_dict) print(type(new_dict)) ------------------------------------------------------------------------------------------ 输出结果: ChainMap({'a': 'zhangsan', 'b': 'lisi'}, {'c': 'wangwu'}, {'d': 'liqui', 'e': 'laowang'}) <class 'collections.ChainMap'>
ChainMap进字典进行查询和遍历
from collections import ChainMap dict1= {"a":"zhangsan","b":"lisi"} dict2= {"c":"wangwu"} dict3= {"d":"liqui","b":"laowang"} new_dict = ChainMap(dict1,dict2,dict3) # 查询,可以直接根据key值查新,和字典操作方式一样 print(new_dict["a"]) print(new_dict["b"]) #当多个字典中有相同的key值是,默认取第一个key对应的value print(new_dict["c"]) print("***"*20) # 遍历,可以直接根据key或者value遍历,和普通字典一样操作 for key,value in new_dict.items(): print(key,":",value)
输出结果:
zhangsan lisi wangwu ************************************************************ e : laowang c : wangwu d : liqui a : zhangsan b : lisi
请注意在合并多个字典时,其重复的键值,默认情况下只取第一个字典中key对应的value值,实际上,这是将这些字典存储在一个队列中列中,这里所有的操作,都是直接操作在字典上的。
三.ChainMap修改
from collections import ChainMap dict1= {"a":"zhangsan","b":"lisi"} dict2= {"c":"wangwu"} dict3= {"d":"liqui","b":"laowang"} new_dict = ChainMap(dict1,dict2,dict3) print("new_dict修改数据之后:",new_dict) print("dict1修改数据之前:",dict1) # 操作列表中索引值为0的字典,修改key="a"对应的value new_dict.maps[0]["a"]=18 print("new_dict修改数据之后:",new_dict) print("dict1修改数据之后:",dict1)
输出结果:
new_dict修改数据之后: ChainMap({'a': 'zhangsan', 'b': 'lisi'}, {'c': 'wangwu'}, {'d': 'liqui', 'b': 'laowang'}) dict1修改数据之前: {'a': 'zhangsan', 'b': 'lisi'} new_dict修改数据之后: ChainMap({'a': 18, 'b': 'lisi'}, {'c': 'wangwu'}, {'d': 'liqui', 'b': 'laowang'}) dict1修改数据之后: {'a': 18, 'b': 'lisi'}
四.ChainMap增加
可以用new_child()函数添加一个新的空白字典,然后像普通字典一样操作添加数据,如:
from collections import ChainMap dict1= {"a":"zhangsan","b":"lisi"} dict2= {"c":"wangwu"} # 合并字典 new_dict = ChainMap(dict1,dict2) print(new_dict) # 添加数据 new_dict1 = new_dict.new_child() print(new_dict1) new_dict1["x"]=0 new_dict1["y"] = 100.0 print(new_dict1)
输出结果:
ChainMap({'a': 'zhangsan', 'b': 'lisi'}, {'c': 'wangwu'}) ChainMap({}, {'a': 'zhangsan', 'b': 'lisi'}, {'c': 'wangwu'}) ChainMap({'x': 0, 'y': 100.0}, {'a': 'zhangsan', 'b': 'lisi'}, {'c': 'wangwu'})
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
SQL Server -- 解决存储过程传入参数作为s
JavaScript判断两个数组相等的四类方法
js如何操作video标签
React实战--利用甘特图和看板,强化Paas平
【记录】正则替换的偏方
前端下载 Blob 类型整理
抽象语法树AST必知必会
关于JS定时器的整理
JS中使用Promise.all控制所有的异步请求都完
js中字符串的方法
import-local执行流程与node模块路径解析流程