一. 初识字典
字典一种 可变容器,可以存储任意类型的数据。字典具有如下特点:
- 数据以键 key- 值value对的形式进行映射存储。
- 字典中的每个数据都是用 “键” 进行索引的,而不像序列可以用下标进行索引。
- 字典的 “键” 不能重复,且只能用不可变类型作为字典的键。
- 数据没有先后顺序关系,字典的存储是无序的。
表示方式
用 {} 括起来,以冒号(:)分隔键 - 值对,键值对之间用逗号分隔开。
创建字典
- 创建空字典:d = {}
- 创建非空字典:d = {"name":"Alex","age":12}、d = {1:"星期一",2:"星期二"}
- 字典的构造函数:
| 函数 | 说明 | 
|---|---|
| dict() | 创建空字典,等同于 {}。 | 
| dict(iterable) | 用可迭代对象初始化一个字典,如: d = dict([('name', 'Alex'), ('age', 13)])。 | 
| dict(**kwargs) | 关键字传参形式生成一个字典,如: d = dict(name='Alex',age=15)。使用此方法,键必须是字符串。 | 
添加和修改字典的元素
使用 字典[键] = 值 的形式向字典中添加或修改元素;当键不存在时,创建键并绑定键对应的值,当键存在时,修改键绑定的对象。
>> d = {key: value for key, value in enumerate("abcde", 1)}
>> d
{1: 'a', 2: 'b', 3: 'c', 4: 'd', 5: 'e'}
>> d[1] = d[1].upper()
>> d
{1: 'A', 2: 'b', 3: 'c', 4: 'd', 5: 'e'}
>> d[0] = 'Python'
>> d
{0: 'Python', 1: 'A', 2: 'b', 3: 'c', 4: 'd', 5: 'e'}
删除字典的元素
del 语句用来删除字典的元素:del dict[key]
成员运算符
in 、not in 运算符用来判断一个 “键” 是否存在于字典中,如果存在则返回 True,否则返回 False。
>> d = {"name": "mia", "age": "18"}
>> "mia" in d
False
>> "name" in d
True
字典的迭代
字典是可迭代对象,直接遍历字典时得到的是字典的键;可以使用索引间接访问值:
>> for key in d:
     print("key={}; value={}".format(key, d[key]))
key=name; value=mia
key=age; value=18
二. 字典常用函数及方法
常用函数一览:
| 函数 | 说明 | 
|---|---|
| len(x) | 返回键值对的个数。 | 
| max(x) | 返回‘’键‘’的最大值。 | 
| min(x) | 返回‘’键‘’的最小值。 | 
| sum(x) | 返回‘’键‘’的和。 | 
| any(x) | 真值测试,如果字典中一个‘’键‘’为真,则结果为真。 | 
| all(x) | 真值测试,字典中所有‘’键‘’为真,则结果才为真。 | 
常用方法一览:
| 方法 | 说明 | 
|---|---|
| D.clear() | 清空字典。 | 
| D.copy() | 浅拷贝返回字典的副本。 | 
| D.get(k[,d]) | 返回键对应的值,没有此键,则返回 default。 | 
| D.items() | 返回键值对组成的可迭代对象。 | 
| D.keys() | 返回字典的键。 | 
| D.values() | 返回字典的值; | 
| D.pop(k[,d]) | 移除键,同时返回此键对应的值;没有此键,则返回 default。 | 
| D.update(D2) | 更新字典;如果 key值重复,则更新为D2中的值。 | 
三. 字典和列表的比较
- 都是可变对象;
- 索引方式不同,列表用整数索引,字典用键索引;
- 列表的存储是有序的,字典的存储是无序的:
- 列表:顺序存储,append()很快,但insert()很慢;
- 字典:映射存储,插入的速度很快。










