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', ...
随机推荐
- A/B test
A/B test https://en.wikipedia.org/wiki/A/B_testing A/B testing (bucket tests or split-run testing) i ...
- 「FHQ Treap」学习笔记
话说天下大事,就像fhq treap —— 分久必合,合久必分 简单讲一讲.非旋treap主要依靠分裂和合并来实现操作.(递归,不维护fa不维护cnt) 合并的前提是两棵树的权值满足一边的最大的比另一 ...
- [BJOI2019]删数(线段树)
[BJOI2019]删数(线段树) 题面 洛谷 题解 按照值域我们把每个数的出现次数画成一根根的柱子,然后把柱子向左推导,\([1,n]\)中未被覆盖的区间长度就是答案. 于是问题变成了单点修改值,即 ...
- 「雅礼集训 2017 Day5」珠宝
题目描述 Miranda 准备去市里最有名的珠宝展览会,展览会有可以购买珠宝,但可惜的是只能现金支付,Miranda 十分纠结究竟要带多少的现金,假如现金带多了,就会比较危险,假如带少了,看到想买的右 ...
- Ticwatch2_3G版省电优化
设置 --> 网络与连接 --> 云消息同步(禁用) 设置 --> 声音与震动 --> 铃声与音量(静音) 设置 --> 声音与震动 --> 闹钟音量(静音) 设置 ...
- Gitlab安装简明文档
1.关于Gitlab CE / GitLab EE版本的区别:Gitlab CE(Community Edition):Gitlab社区版,可以免费试用,无官方支持.GitLab EE(Enterpr ...
- 重学JavaScript - 数组
作者:狐狸家的鱼 GitHub:surRimn 整理自MDN文档 数组 数组是一种类列表对象,长度和元素类型不固定. 描述 访问数组 JavaScript数组的索引是从0开始的,第一个元素的索引为0, ...
- IIS8的SNI功能实现同一服务器多HTTPS站点
名词解释: SNI指是一项用于改善SSL/TLS的技术,在SSLv3/TLSv1中被启用.它允许客户端在发起SSL握手请求时(具体说来,是客户端发出SSL请求中的ClientHello阶段),就提交请 ...
- ROS time stamp and sync
1. https://answers.ros.org/question/189867/what-is-the-timestamp/ In ROS messages timestamp is taken ...
- Transformer【Attention is all you need】
前言 Transfomer是一种encoder-decoder模型,在机器翻译领域主要就是通过encoder-decoder即seq2seq,将源语言(x1, x2 ... xn) 通过编码,再解码的 ...