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. Python基础:编码规范(4)

    1.命名规范 Python中不同代码元素采用不同命名方式: ◊ 包名:全部小写字母,中间可以由点分隔开.作为命名空间,包名需具有唯一性. ◊ 模块名:全部小写字母,如果是多个单词构成,使用下划线分隔. ...

  2. kafka基本介绍

    kafka基础知识 几个概念 kafka作为一个集群运行在一个或多个服务器上.kafka集群存储的消息是以topic为类别记录的.每个消息(也叫记录record,我习惯叫消息)是由一个key,一个va ...

  3. 【LOJ#2402】[THUPC2017]天天爱射击(整体二分)

    [LOJ#2402][THUPC2017]天天爱射击(整体二分) 题面 LOJ 题解 显然对于每块木板可以二分被打烂的时间. 那么直接上整体二分处理就行了. #include<iostream& ...

  4. [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+ ...

  5. [unix]commvault在unix系统上本地安装报“NFS directory cannot be used”

    远程安装持续的pending: 本地安装报“NFS directory cannot be used” 修改安装包 安装目录 的权限, 从777改回775. 就可以解决这个报错.

  6. 使用sshpass同时更新一台ubuntu和一台CentOS

    1.在ubuntu上安装sshpass sudo apt install sshpass 2.分别在两台的root路径下放上升级脚本: cent:/root/upgrade.sh #!/bin/bas ...

  7. [BJOI2017]树的难题

    题目描述 给你一棵 n 个点的无根树. 树上的每条边具有颜色.一共有 m 种颜色,编号为 1 到 m.第 i 种颜色的权值为 ci. 对于一条树上的简单路径,路径上经过的所有边按顺序组成一个颜色序列, ...

  8. Vue针对性笔记

    Github原文阅读 MVVM(Model-View-ViewModel)模型 MVVM分为Model.View.ViewModel三部分. Model代表数据模型,定义数据和业务逻辑,访问数据层 V ...

  9. 3194. 【HNOI模拟题】化学(无标号无根树计数)

    Problem 求\(n\)个点的每个点度数不超过\(4\)的无标号无根树个数. Data constraint \(1\le n\le 500\) Solution 尝试着把问题一般化.我们来考虑一 ...

  10. Grains 与 Pillars

    Grains 与 Pillars Grains介绍 Grains接口是salt用来采集底层系统信息的,包含了操作系统信息.域名.IP地址.内核.内存等一些底层信息.就是因为grains采集了这些信息, ...