字典 = {'键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基础教程:字典的更多相关文章

  1. 《python基础教程(第二版)》学习笔记 字典(第4章)

    <python基础教程(第二版)>学习笔记 字典(第4章)创建字典:d={'key1':'value1','key2':'value2'}lst=[('key1','value1'),(' ...

  2. Python基础教程2上的一处打印缺陷导致的代码不完整#1

    #1对代码的完善的 出现打印代码处缺陷截图: 图片上可以看到,定义的request根本没有定义它就有了.这个是未定义的,会报错的,这本书印刷问题,这个就是个坑,我也是才发现.花了点时间脱坑. 现在发完 ...

  3. python基础教程(第二版)

    开始学习python,根据Python基础教程,把里面相关的基础章节写成对应的.py文件 下面是github上的链接 python基础第1章基础 python基础第2章序列和元组 python基础第3 ...

  4. 【Python】Python基础教程系列目录

    Python是一个高层次的结合了解释性.编译性.互动性和面向对象的脚本语言. 在现在的工作及开发当中,Python的使用越来越广泛,为了方便大家的学习,Linux大学 特推出了 <Python基 ...

  5. Python基础教程系列目录,最全的Python入门系列教程!

    Python是一个高层次的结合了解释性.编译性.互动性和面向对象的脚本语言. 在现在的工作及开发当中,Python的使用越来越广泛,为了方便大家的学习,Linux大学 特推出了 <Python基 ...

  6. 《python基础教程(第二版)》学习笔记 语句/循环/条件(第5章)

    <python基础教程(第二版)>学习笔记 语句/循环/条件(第5章) print 'AB', 123 ==> AB 123 # 插入了一个空格print 'AB', 'CD' == ...

  7. Python基础教程总结(一)

    引言: 一直都听说Python很强大,以前只是浏览了一些博客,发现有点像数学建模时使用的Matlab,就没有深入去了解了.如今Python使用的地方越来越多,最近又在学习机器学习方面的知识,因此想系统 ...

  8. 学习参考《Python基础教程(第3版)》中文PDF+英文PDF+源代码

    python基础教程ed3: 基础知识 列表和元组 字符串 字典 流程控制 抽象(参数 作用域 递归) 异常 魔术方法/特性/迭代器 模块/标准库 文件 GUI DB 网络编程 测试 扩展python ...

  9. Python基础教程(第2版 修订版) pdf

    Python基础教程(第2版 修订版) 目录 D11章快速改造:基础知识11.1安装Python11.1.1Windows11.1.2Linux和UNIX31.1.3苹果机(Macintosh)41. ...

  10. Python基础教程-02

    <Python基础教程> 第3章 使用字符串 字符串方法find返回的并非布尔值.如果find像这样返回0,就意味着它在索引0处找到 了指定的子串 join可合并一个字符串列表,不能合并数 ...

随机推荐

  1. 杭电oj 蟠桃记

    Problem Description 喜欢西游记的同学肯定都知道悟空偷吃蟠桃的故事,你们一定都觉得这猴子太闹腾了,其实你们是有所不知:悟空是在研究一个数学问题!什么问题?他研究的问题是蟠桃一共有多少 ...

  2. Java-【Arrays类】和【System类】

    Arrays类 [基本介绍] JDK中提供了一个专门用于操作数组的工具类,即Arrays类,位于java util 中. 用前需导包:import java.util.Arrays; [常用方法] 返 ...

  3. maven 依赖包冲突解决

    maven 查看依赖树结构命令mvn dependency:tree 1.出现下面这样冲突 omitted for duplicate  因重复而省略 2.解决-- 那个项目有问题,先注释掉,在重新一 ...

  4. 简单a+b

    1 # include <stdio.h> 2 3 /*输入两个整数a和b,计算a+b的和 4 注意此题是多组测试数据 */ 5 6 // 我的解法 7 void main(){ 8 in ...

  5. spring-security-oauth2-authorization-server

    旧依赖的移除 长久以来,使用Spring Security整合oauth2,都是使用Spring Security Oauth2这个系列的包: <dependency> <group ...

  6. IIS 7.0、IIS 7.5 和 IIS 8.0 中的 HTTP 状态代码

    https://support.microsoft.com/zh-cn/help/943891/the-http-status-code-in-iis-7-0--iis-7-5--and-iis-8- ...

  7. Python pdb模块的使用

    野路子出生,写Python也有段时间了,一般的调试都用的print, PyCharm的debug功能也用的比较少,主要一般也用不到,第二是自己也不怎么会用. 服务器开发,本地根本没有运行的环境,前面学 ...

  8. ORA-00972: identifier is too long异常处理

    环境:由于数据库更换,做数据同步,提示 too long 问题,导致一直无法同步完数据. 经排查 oracle 历史数据库版本: Oracle Database 12c Standard Editio ...

  9. 如何在VM虚拟机里建立Linux操作系统

    1.新建虚拟机 2.选择典型安装 3.选择稍后安装操作系统 4.选择Linux操作系统和CentOS 7 64位 5.选择文件路径 注意:建议每台虚拟机单独文件夹保存,并且此处路径最好不要有中文出现 ...

  10. org.nutz.http.Http忽略https SSL证书验证

    访问的是一个https get请求,报错需要SSL证书验证,以下方法直接跳过 boolean check = Http.disableJvmHttpsCheck(); // 忽略https的证书检查