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(字典)的更多相关文章

  1. 【cf842D】Vitya and Strange Lesson(01字典树)

    D. Vitya and Strange Lesson 题意 数列里有n个数,m次操作,每次给x,让n个数都异或上x.并输出数列的mex值. 题解 01字典树保存每个节点下面有几个数,然后当前总异或的 ...

  2. Vitya and Strange Lesson CodeForces - 842D 字典树+交换节点

    题意: Today at the lesson Vitya learned a very interesting function - mex. Mex of a sequence of number ...

  3. codeforces 842 D. Vitya and Strange Lesson(01字典树+思维+贪心)

    题目链接:http://codeforces.com/contest/842/problem/D 题解:像这种求一段异或什么的都可以考虑用字典树而且mex显然可以利用贪心+01字典树,和线段树差不多就 ...

  4. 【DG】Oracle_Data_Guard官方直译

    [DG]Oracle Data Guard官方直译 1 Oracle Data Guard 介绍   Oracle Data Guard概念和管理10g版本2   Oracle Data Guard ...

  5. DVWA实验之Brute Force(暴力破解)- Low

    DVWA实验之Brute Force-暴力破解- Low     这里开始DVWA的相关实验~   有关DVWA环境搭建的教程请参考: https://www.cnblogs.com/0yst3r-2 ...

  6. Oracle错误览表

    Oracle 错误总结及问题解决 ORA     本文转自:https://www.cnblogs.com/zhangwei595806165/p/4972016.html  作者@承影剑 ORA-0 ...

  7. CodeForeces 842d Vitya and Strange Lesson ——(带lazy标记的01字典树)

    给一个序列,每次操作对这个序列中的所有数异或一个x,问每次操作完以后整个序列的mex值. 做法是去重后构建01字典树,异或x就是对root加一个x的lazy标志,每次pushDown时如果lazy的这 ...

  8. dictionary(字典)

    dictionary(字典):   字典对象   字典是一种key - value 的数据类型,使用就像我们上学用的字典,通过笔划.字母来查对应页的详细内容. 1.      dic={"n ...

  9. 7、字典和string的用法

    #dic={1:'alex','age':35,'hobby':{'girl_name':'铁锤','age':45},'is_handsome':True} # dic={'age':'alex', ...

随机推荐

  1. Leetcode 8 Two Pointers

    Two Pointers 1. 28. Implement strStr() 用 i 记录haystack偏移量,j 记录 needle 的偏移量. class Solution { public i ...

  2. docker 笔记

     批量删除Docker中已经停止的容器[转] 方法一: #显示所有的容器,过滤出Exited状态的容器,取出这些容器的ID, sudo docker ps -a|grep Exited|awk '{p ...

  3. PWA 渐进式Web应用程序 - 解释

    想象一下,如果一个网站上所有的功能都能够作为一个移动应用程序为用户所用——任何设备上都可以使用.可接收所有的通知.离线模式可用,为了实现这个愿景,2015年,谷歌创造了渐进式Web应用程序(PWA). ...

  4. manjaro下的.vimrc

    我的插件管理是用vim-plug来管理的 下载命令 curl -fLo ~/.vim/autoload/plug.vim --create-dirs \ https://raw.githubuserc ...

  5. filter的使用

    (1)什么是filter 过滤器是处于客户端与服务器资源文件之间的一道过滤网,在访问资源文件之前,通过一系列的过滤器对请求进行修改,判断等,把不符合规则的请求在中途拦截或者修改.或者对响应进行过滤.拦 ...

  6. python9--内存管理 引用计数 标记清除 分代回收

     复习   文件处理 1.操作文件的三步骤 -- 打开文件:硬盘的空间被操作系统持有 | 文件对象被应用程序持续 -- 操作文件:读写操作 -- 释放文件:释放操作系统对硬盘空间的持有 2.基础的读写 ...

  7. 【tensorflow】学习笔记

    1.tensorflow中dynamic_rnn和rnn有什么区别?    在tensorflow中没有找到rnn这个方法难道是废弃掉了? rnn是静态图,比如有10个时间序列,那么它将全部展开,并且 ...

  8. pandas技巧两则——列内元素统计和列内元素排序

    更新:后来忽然发现有个cumcount()函数,支持正排倒排,所以以下说的那些基本都没啥用了. 最近做比赛线上无甚进展,所以先小小地总结遇到的一些困难和解决的方法,以防之后忘记.毕竟总是忙着大步赶路的 ...

  9. .NET框架 - NETCORE + API + EF + MYSQL

    .NET框架 - NETCORE + API + EFCORE + MYSQL 1. 新建项目: 本文中使用 框架 .netcore2.2 . 2. 生成项目框架 3 安装MYSQL插件 点击“工具” ...

  10. hadoop记录-Hadoop参数汇总

    Hadoop参数汇总 linux参数 以下参数最好优化一下: 文件描述符ulimit -n 用户最大进程 nproc (hbase需要 hbse book) 关闭swap分区 设置合理的预读取缓冲区 ...