Python基础教程:字典
字典 = {'键1':'值1','键2':'值2','键3':'值3',...}
animal_dict = {'Cow':'Milk','Chicken':'egg'}
字典由键值对构成,这种键值对称为项。在字典(及其他映射类型中),键是唯一的,而值无需如此
——字典是Python中唯一的内置映射类型,其中的值不按顺序排列,而是存储在键下
一、函数dict
>>> lst = [[1,2],[3,4]]
>>> dct = dict(lst)
>>> dct
{1: 2, 3: 4}
二、format_map
'字符串{键名}'.format_map(键名所在字典)
作用:字典中包含各种信息,只需在格式字符串中提取所需的信息即可
>>> '张三来自于{省份}{城市}'.format_map(dict_v['张三'])
'张三来自于浙江杭州'
>>> dict_v = {'张三':{'省份':'浙江','城市':'杭州'},'李四':{'省份':'浙江','城市':'嘉兴'},'王五':{'省份':'浙江','城市':'杭州'},'李六':{'省份':'江苏','城市':'南京'}}
>>> '张三来自于{省份}{城市}'.format_map(dict_v['张三'])
'张三来自于浙江杭州'
>>> '李四来自于{省份}{城市}'.format_map(dict_v['李四'])
'李四来自于浙江嘉兴'
三、字典方法
1、clear
字典.clear()
作用:删除所有字典项
>>> x = {}
>>> y = x #y和x指向同一字典
>>> x['key'] = 'value'
>>> y
{'key': 'value'}
>>> x
{'key': 'value'}
>>> x = {} #x指向另一个字典
>>> x
{} #x是新字典的值
>>> y
{'key': 'value'} #所以y还是原来字典的值
>>> x = {}
>>> y = x #y和x指向同一字典
>>> x['key'] = 'value'
>>> y
{'key': 'value'}
>>> x.clear() #y和x共同指向的字典清空
>>> y
{}
2、copy/deepcopy,浅复制/深复制
字典.copy()
from copy import deepcopy deepcopy(字典)
要理解浅复制和深复制的区别,首先要了解python存储数据的方式。变量 = 值1,是把变量指向了值1(内存地址1),假使重新给变量赋值为值2(内存地址2) ,那么变量和值1的映射关系没有了,替换为变量指向值2。
>>> from copy import deepcopy
>>> dict_orign = {'key':{'1':'1','2':'2'}}
>>> copy1 = dict_orign.copy()
>>> copy2 = deepcopy(dict_orign)
>>> id(dict_orign)
2442900992712 #原件在内存中的地址
>>> id(copy1)
2442900738280 #浅复制副本1在内存中的地址
>>> id(copy2)
2442900992392 #深复制副本2在内存中的地址
>>> id(dict_orign['key'])
2442900975032 #原件字典项中值在内存中的地址
>>> id(copy1['key'])
2442900975032 #浅复制副本1字典项中值在内存中的地址
>>> id(copy2['key'])
2442900992552 #深复制副本2字典项中值在内存中的地址
↑↑↑见上述,原件和浅复制副本字典项-值在内存中的地址是一样的,而深复制完全不同,所以深复制后续的操作与原件不相关
>>> M = {'1':['1','2','3']}
>>> m1 = M.copy()
>>> id(M['1'])
2442869287688
>>> id(m1['1'])
2442869287688 #浅复制时,副本和原件值指向的内存地址都是2442869287688
>>> m1['1'].remove('3') #在既有内存地址上修改
>>> M
{'1': ['1', '2']} #原件也跟着副本的修改而变动了
>>> id(M['1'])
2442869287688
>>> id(m1['1'])
2442869287688 #值指向的内存地址还是原先的2442869287688
>>> m1['1'] = ['1','1','1'] #副本值重新赋值,也就是指向了新的内存地址
>>> M
{'1': ['1', '2']} #因为副本和原件值指向的内存地址不同,所以副本的变更不影响原件
>>> id(M['1'])
2442869287688
>>> id(m1['1'])
2442900925064 #副本内存地址已变更
3、fromkeys
{}.fromkeys([键名列表],值),值为选填项,不填则每个键对应的值都是None,填则每个键对应的值都是设置值
dict.fromkeys([键名列表],值),值为选填项,不填则每个键对应的值都是None,填则每个键对应的值都是设置值
作用:创建一个新字典,其中包含指定的键,且每个键对应的值都是None
>>> {}.fromkeys(['name', 'age'])
{'age': None, 'name': None}
>>> dict.fromkeys(['name', 'age'])
{'age': None, 'name': None}
>>> dict.fromkeys(['name', 'age'], '(unknown)')
{'age': '(unknown)', 'name': '(unknown)'}
4、get
字典.get(键,值),值为选填项,不填则若无此项返回None,填则若无此项返回设定值
作用:访问字典中的项,如果存在,则与普通字典查找一致;如果不存在则返回None,也可将None替换为其他值。
>>> d = {}
>>> print(d['name'])
Traceback (most recent call last):
File "<stdin>", line 1, in ?
KeyError: 'name'
>>> print(d.get('name'))
None
>>> d.get('name', 'N/A')
'N/A'
5、items
字典.items()
作用:(1)返回一个包含所有字典项的列表,其中每个元素都为(key,value)形式
(2)字典项在列表中无序排序
(3)items非副本,如果字典发生变化,items也会响应改变
>>> d = {'title': 'Python Web Site', 'url': 'http://www.python.org', 'spam': 0}
>>> d.items()
dict_items([('url', 'http://www.python.org'), ('spam', 0), ('title', 'Python Web Site')])
返回值属于一种名为字典视图的特殊类型。字典视图可用于迭代(迭代将在第5章详细介绍)。
另外,你还可确定其长度以及对其执行成员资格检查。
>>> it = d.items()
>>> len(it)
3
>>> ('spam', 0) in it
True
视图的一个优点是不复制,它们始终是底层字典的反映,即便你修改了底层字典亦如此。
>>> d['spam'] = 1
>>> ('spam', 0) in it
False
>>> d['spam'] = 0
>>> ('spam', 0) in it
True
6、keys
方法keys返回一个字典视图,其中包含指定字典中的键。
7、pop方法
字典.pop(键名)
作用:pop可用于获取与指定键相关联的值,并将该键值对从字典中删除。
>>> d = {'x': 1, 'y': 2}
>>> d.pop('x')
1
>>> d
{'y': 2}
8、popitem
字典.popitem()
作用:随机弹出键值对,可用于逐个处理字典项场景,这样无需提供键名
>>> d = {'url': 'http://www.python.org', 'spam': 0, 'title': 'Python Web Site'}
>>> d.popitem()
('url', 'http://www.python.org')
>>> d
{'spam': 0, 'title': 'Python Web Site'}
9、setdefault
字典.setdefault(键,值),值为选填项,不填则若无此项值为None,字典新增此键值对;填则若无此项值为设定值,字典新增此键值对
作用:类似于get,但键不存在时,会在字典中添加指定键值对
>>> d = {}
>>> d.setdefault('name', 'N/A')
'N/A'
>>> d
{'name': 'N/A'}
>>> d['name'] = 'Gumby'
>>> d.setdefault('name', 'N/A')
'Gumby'
>>> d
{'name': 'Gumby'}
>>> d = {}
>>> print(d.setdefault('name'))
None
>>> d
{'name': None}
10、update
字典1.update(字典2)
作用:使用字典2中的项来更新字典1,若存在相同项,则用字典2的值替换字典1的值
>>> d = {
... 'title': 'Python Web Site',
... 'url': 'http://www.python.org',
... 'changed': 'Mar 14 22:09:15 MET 2016'
... }
>>> x = {'title': 'Python Language Website'}
>>> d.update(x)
>>> d
{'url': 'http://www.python.org', 'changed':
'Mar 14 22:09:15 MET 2016', 'title': 'Python Language Website'}
11、values
字典.values()
作用:返回值组成的字典视图,keys因为键特性,不会重复,values返回的可能包含重复值
>>> d = {}
>>> d[1] = 1
>>> d[2] = 2
>>> d[3] = 3
>>> d[4] = 1
>>> d.values()
dict_values([1, 2, 3, 1])
Python基础教程:字典的更多相关文章
- 《python基础教程(第二版)》学习笔记 字典(第4章)
<python基础教程(第二版)>学习笔记 字典(第4章)创建字典:d={'key1':'value1','key2':'value2'}lst=[('key1','value1'),(' ...
- Python基础教程2上的一处打印缺陷导致的代码不完整#1
#1对代码的完善的 出现打印代码处缺陷截图: 图片上可以看到,定义的request根本没有定义它就有了.这个是未定义的,会报错的,这本书印刷问题,这个就是个坑,我也是才发现.花了点时间脱坑. 现在发完 ...
- python基础教程(第二版)
开始学习python,根据Python基础教程,把里面相关的基础章节写成对应的.py文件 下面是github上的链接 python基础第1章基础 python基础第2章序列和元组 python基础第3 ...
- 【Python】Python基础教程系列目录
Python是一个高层次的结合了解释性.编译性.互动性和面向对象的脚本语言. 在现在的工作及开发当中,Python的使用越来越广泛,为了方便大家的学习,Linux大学 特推出了 <Python基 ...
- Python基础教程系列目录,最全的Python入门系列教程!
Python是一个高层次的结合了解释性.编译性.互动性和面向对象的脚本语言. 在现在的工作及开发当中,Python的使用越来越广泛,为了方便大家的学习,Linux大学 特推出了 <Python基 ...
- 《python基础教程(第二版)》学习笔记 语句/循环/条件(第5章)
<python基础教程(第二版)>学习笔记 语句/循环/条件(第5章) print 'AB', 123 ==> AB 123 # 插入了一个空格print 'AB', 'CD' == ...
- Python基础教程总结(一)
引言: 一直都听说Python很强大,以前只是浏览了一些博客,发现有点像数学建模时使用的Matlab,就没有深入去了解了.如今Python使用的地方越来越多,最近又在学习机器学习方面的知识,因此想系统 ...
- 学习参考《Python基础教程(第3版)》中文PDF+英文PDF+源代码
python基础教程ed3: 基础知识 列表和元组 字符串 字典 流程控制 抽象(参数 作用域 递归) 异常 魔术方法/特性/迭代器 模块/标准库 文件 GUI DB 网络编程 测试 扩展python ...
- Python基础教程(第2版 修订版) pdf
Python基础教程(第2版 修订版) 目录 D11章快速改造:基础知识11.1安装Python11.1.1Windows11.1.2Linux和UNIX31.1.3苹果机(Macintosh)41. ...
- Python基础教程-02
<Python基础教程> 第3章 使用字符串 字符串方法find返回的并非布尔值.如果find像这样返回0,就意味着它在索引0处找到 了指定的子串 join可合并一个字符串列表,不能合并数 ...
随机推荐
- python实现字典的排序
var dic = {c:4, a:2, d:3, b:1}; // 定义一个字典 console.log("输出最初的字典元素: "); for(var key in dic){ ...
- Ubuntu 20.04 部署Prmoetheus+grafana+mysql+mysqld_exporter+node_exporter
Prometheus简介 Prometheus是一个功能强大的开源监控系统,可从您的服务中收集指标并将其存储在时间序列数据库中.它通过Grafana等工具提供多维数据模型,灵活的查询语言和多样化的可视 ...
- IDEA+SpringBoot整合Swagger2创建API文档
------------恢复内容开始------------ 1.创建SpringBoot项目 2.选择快捷方式创建springboot项目 3.工程文件树形图 4.pom.xml中导入Swagger ...
- 解决xpath提取的数据列表,保存时不能一一对应的问题
"""拉链函数,zip将几个列表的数据进行封装,一一对应.如果一方列表的数据,比另一方少,那么按数据少的一方对应"""# 数据个数对应相等l ...
- JavaScript 调用Bomb后端云
用简单的代码 展示代码的魅力 Bmob 是后端云 全方位一体化的后端服务平台 提供可靠的 Server ...
- ProcessLassoLauncher.exe
html, body { font-size: 15px } body { font-family: Helvetica, "Hiragino Sans GB", 微软雅黑, &q ...
- linux 第一节(基本命令)
RPM 红帽软件管理器,(源代码+安装规则打包) YUM 软件仓库yum源,打包了大量的软件. yum repolist all //列出所有仓库 ...
- 对synchronized的理解和Spring为什么是单例的
只有真正理解了Java中对象是什么,才能理解这个关键字是什么意思 字面解释 Java Guide中如此解释: synchronized 关键字解决的是多个线程之间访问资源的同步性,synchroniz ...
- ios MJRefresh 上拉死循环刷新问题+git 图片
网上各种办法都试了,只有这种解决方法解决了我的问题,记录一下 通过延迟 1s后,再来请求接口 - (void)viewDidLoad { [super viewDidLoad]; // Do any ...
- OO课程第一阶段(前三次作业)总结Blog1
OO课程第一阶段(前三次作业)总结Blog1 前言:学习OOP课程的第一阶段已经结束了,在此进行对于知识点,题量,难度的个人看法. (1)相比于另外两次作业,第一次作业基本上是基本的编程的语法训练,题 ...