一. 初识字典
字典一种 可变容器,可以存储任意类型的数据。字典具有如下特点:
- 数据以键
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()
很慢; - 字典:映射存储,插入的速度很快。