Python 字典

时间:2021-7-5 作者:qvyue

一. 初识字典

字典一种 可变容器,可以存储任意类型的数据。字典具有如下特点:

  • 数据以键 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]

成员运算符

innot 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() 很慢;
  • 字典:映射存储,插入的速度很快。
声明:本文内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:qvyue@qq.com 进行举报,并提供相关证据,工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。