Lesson 2-4(字典)
2.7 字典
&、字典是许多值的集合,索引可以使用许多不同的数据类型,不只是整数,可以是数、字符串或元组。
&、字典的索引被称为“键”,键及其关联的值称为“键-值”对,这种键-值对也称为项。
&、字典是python中唯一的内置映射类型,其中的值不按顺序排列,而是存储在键下。
&、字典中的项不排序,所以不能像列表那样切片;访问字典中不存在的键时,将会报错。
2.7.1 创建字典
--- 字典可使用花括号创建,每个键及值之间用冒号分隔,项之间用逗号分隔;空字典只用两个花括号表示,花括号内没有任何项。
--- 可是用函数dict从其它映射或键值对序列创建字典。
>>> dic_1 = {'name': 'LiMing', 'age': 20}
>>> items = [('name', 'Maly'), ('age', 18)]
>>> dic_2 = dict(items)
--- 可以使用关键字实参来调用dict函数。
>>> dict_3 = dict(name = 'Grubby', age = 25)
>>> dict_3
{'name': 'Grubby', 'age': 25}
>>>
2.7.2 基础操作
--- 方法keys()、values()、items()分别返回对应的字典的键、值和键值对的值。
--- 返回的值类似于列表但不是列表,不能被修改, 分别是dict_keys、dict_values 和 dict_items类型,可用于for循环。
>>> dic = {'a':1, 'b':2, 'c':3}
>>> dic.keys()
dict_keys(['a', 'b', 'c'])
>>> dic.values()
dict_values([1, 2, 3])
>>> dic.items()
dict_items([('a', 1), ('b', 2), ('c', 3)])
>>> type(dic.keys())
<class 'dict_keys'>
>>> type(dic.values())
<class 'dict_values'>
>>> type(dic.items())
<class 'dict_items'>
>>>
--- len(dic)返回字典dic包含的项数。
--- dic[key]返回字典dic中键key对应的值。
--- dic[key]=value将字典dic中键key的值更新为value,如原字典dic中没有该键key,则增加该项到字典dic中。
--- del dic[key]将删除字典dic中键key的项(键值对)。
1 >>> dic = {'a':1, 'b':2, 'c':3}
2 >>> len(dic)
3 3
4 >>> dic['b']
5 2
6 >>> dic['c'] = 5
7 >>> dic
8 {'a': 1, 'b': 2, 'c': 5}
9 >>> del dic['a']
10 >>> dic
11 {'b': 2, 'c': 5}
12 >>>
13 >>> dic['f'] = 10
14 >>> dic
15 {'b': 2, 'c': 5, 'f': 10}
16 >>>
--- 成员资格,使用in和not in操作符判定。
>>> dic = {'a':1, 'b':2, 'c':3}
>>> 'b' in dic.keys()
True
>>> 'f' in dic.keys()
False
>>> 'b' in dic.values()
False
>>> '' in dic.values()
False
>>> 3 in dic.values()
True
>>>
2.7.3 常用方法
--- get()方法:如果试图访问字典中没有的项,将引发错误,使用方法get,则很好的解决该问题。方法get有两个参数,第一个是要取得其值的键,必选;第二个是字典中没有要访问的项时返回的值,可选,不选时默认返回None。
>>> dic = {'a':1, 'b':2, 'c':3}
>>> print(dic['f'])
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
KeyError: 'f'
>>> print(dic.get('f'))
None
>>> print(dic.get('b'))
2
>>> print(dic.get('f', 'N/A'))
N/A
>>>
--- setdefault()方法:该方法设置字典中要检测的键的默认值。两个参数,第一个参数是要设置的键;第二个参数是,如果字典中没有该项,则该参数赋给该项并返回该值,如果字典中有该项则返回该项中的值。
>>> dic = {'a':1, 'b':2, 'c':3}
>>> print(dic)
{'a': 1, 'b': 2, 'c': 3}
>>> print(dic.setdefault('b', 100))
2
>>> print(dic)
{'a': 1, 'b': 2, 'c': 3}
>>> print(dic.setdefault('f', 200))
200
>>> print(dic)
{'a': 1, 'b': 2, 'c': 3, 'f': 200}
>>>
--- keys()方法和values()方法:分别返回一个字典视图,分别包含字典中的所有键和字典中的所有值。
>>> dic = {'a':1, 'b':2, 'c':3}
>>> print(dic.keys())
dict_keys(['a', 'b', 'c'])
>>> print(dic.values())
dict_values([1, 2, 3])
>>>
--- items()方法:返回一个包含所有字典项的字典视图,其中每个元素都为(key,values)的形式。
>>> dic = {'a':1, 'b':2, 'c':3}
>>> print(dic.items())
dict_items([('a', 1), ('b', 2), ('c', 3)])
>>> print(len(dic.items()))
3
>>> print(list(dic.items()))
[('a', 1), ('b', 2), ('c', 3)]
>>>
--- pop()方法:获取与指定键相关联的值,并将该项从字典中删除。
>>> dic = {'a':1, 'b':2, 'c':3}
>>> print(dic.pop('c'))
3
>>> print(dic)
{'a': 1, 'b': 2}
>>>
---popitem()方法:类似list.pop(),list.pop()弹出列表中的最后一个元素,popitem()随机弹出一个字典项。
>>> dic = {'a':1, 'b':2, 'c':3}
>>> print(dic.popitem())
('c', 3)
>>> print(dic)
{'a': 1, 'b': 2}
>>>
--- formkeys()方法:创建一个新字典,包含指定的键,且每个键对应的值默认是None,也可指定一个值。
>>> print(dic.fromkeys(['a','b']))
{'a': None, 'b': None}
>>> print(dic.fromkeys(['a','b'], 'N/A'))
{'a': 'N/A', 'b': 'N/A'}
>>>
--- copy()方法:执行浅复制,返回一个新字典,包含的项与原来的字典相同。
>>> dic_1 = {'a':1, 'b':2, 'c':3}
>>> dic_2 = dic_1.copy()
>>> print(dic_1)
{'a': 1, 'b': 2, 'c': 3}
>>> print(dic_2)
{'a': 1, 'b': 2, 'c': 3}
>>> dic_1['c'] = 99
>>> print(dic_1)
{'a': 1, 'b': 2, 'c': 99}
>>> print(dic_2)
{'a': 1, 'b': 2, 'c': 3}
>>> del dic_1['a']
>>> print(dic_1)
{'b': 2, 'c': 99}
>>> print(dic_2)
{'a': 1, 'b': 2, 'c': 3}
>>>
--- clear()方法:删除所有的字典项,并返回None。
>>> dic = {'a':1, 'b':2, 'c':3}
>>> print(dic)
{'a': 1, 'b': 2, 'c': 3}
>>> print(dic.clear())
None
>>> print(dic)
{}
>>>
Lesson 2-4(字典)的更多相关文章
- 【cf842D】Vitya and Strange Lesson(01字典树)
D. Vitya and Strange Lesson 题意 数列里有n个数,m次操作,每次给x,让n个数都异或上x.并输出数列的mex值. 题解 01字典树保存每个节点下面有几个数,然后当前总异或的 ...
- Vitya and Strange Lesson CodeForces - 842D 字典树+交换节点
题意: Today at the lesson Vitya learned a very interesting function - mex. Mex of a sequence of number ...
- codeforces 842 D. Vitya and Strange Lesson(01字典树+思维+贪心)
题目链接:http://codeforces.com/contest/842/problem/D 题解:像这种求一段异或什么的都可以考虑用字典树而且mex显然可以利用贪心+01字典树,和线段树差不多就 ...
- 【DG】Oracle_Data_Guard官方直译
[DG]Oracle Data Guard官方直译 1 Oracle Data Guard 介绍 Oracle Data Guard概念和管理10g版本2 Oracle Data Guard ...
- DVWA实验之Brute Force(暴力破解)- Low
DVWA实验之Brute Force-暴力破解- Low 这里开始DVWA的相关实验~ 有关DVWA环境搭建的教程请参考: https://www.cnblogs.com/0yst3r-2 ...
- Oracle错误览表
Oracle 错误总结及问题解决 ORA 本文转自:https://www.cnblogs.com/zhangwei595806165/p/4972016.html 作者@承影剑 ORA-0 ...
- CodeForeces 842d Vitya and Strange Lesson ——(带lazy标记的01字典树)
给一个序列,每次操作对这个序列中的所有数异或一个x,问每次操作完以后整个序列的mex值. 做法是去重后构建01字典树,异或x就是对root加一个x的lazy标志,每次pushDown时如果lazy的这 ...
- dictionary(字典)
dictionary(字典): 字典对象 字典是一种key - value 的数据类型,使用就像我们上学用的字典,通过笔划.字母来查对应页的详细内容. 1. dic={"n ...
- 7、字典和string的用法
#dic={1:'alex','age':35,'hobby':{'girl_name':'铁锤','age':45},'is_handsome':True} # dic={'age':'alex', ...
随机推荐
- Python基础:编码规范(4)
1.命名规范 Python中不同代码元素采用不同命名方式: ◊ 包名:全部小写字母,中间可以由点分隔开.作为命名空间,包名需具有唯一性. ◊ 模块名:全部小写字母,如果是多个单词构成,使用下划线分隔. ...
- kafka基本介绍
kafka基础知识 几个概念 kafka作为一个集群运行在一个或多个服务器上.kafka集群存储的消息是以topic为类别记录的.每个消息(也叫记录record,我习惯叫消息)是由一个key,一个va ...
- 【LOJ#2402】[THUPC2017]天天爱射击(整体二分)
[LOJ#2402][THUPC2017]天天爱射击(整体二分) 题面 LOJ 题解 显然对于每块木板可以二分被打烂的时间. 那么直接上整体二分处理就行了. #include<iostream& ...
- [Windows Hyper-V-Server]Enable or disable firewall rules under powershell / powershell下启用禁用防火墙规则
http://www.cryer.co.uk/brian/windows/hyper-v-server/help_computer_cannot_be_managed.htm Enable COM+ ...
- [unix]commvault在unix系统上本地安装报“NFS directory cannot be used”
远程安装持续的pending: 本地安装报“NFS directory cannot be used” 修改安装包 安装目录 的权限, 从777改回775. 就可以解决这个报错.
- 使用sshpass同时更新一台ubuntu和一台CentOS
1.在ubuntu上安装sshpass sudo apt install sshpass 2.分别在两台的root路径下放上升级脚本: cent:/root/upgrade.sh #!/bin/bas ...
- [BJOI2017]树的难题
题目描述 给你一棵 n 个点的无根树. 树上的每条边具有颜色.一共有 m 种颜色,编号为 1 到 m.第 i 种颜色的权值为 ci. 对于一条树上的简单路径,路径上经过的所有边按顺序组成一个颜色序列, ...
- Vue针对性笔记
Github原文阅读 MVVM(Model-View-ViewModel)模型 MVVM分为Model.View.ViewModel三部分. Model代表数据模型,定义数据和业务逻辑,访问数据层 V ...
- 3194. 【HNOI模拟题】化学(无标号无根树计数)
Problem 求\(n\)个点的每个点度数不超过\(4\)的无标号无根树个数. Data constraint \(1\le n\le 500\) Solution 尝试着把问题一般化.我们来考虑一 ...
- Grains 与 Pillars
Grains 与 Pillars Grains介绍 Grains接口是salt用来采集底层系统信息的,包含了操作系统信息.域名.IP地址.内核.内存等一些底层信息.就是因为grains采集了这些信息, ...