Python字典
- 什么是字典
- 字典特点
- 和list列表对比
- 字典原理
- 字典的创建
- 创建方式
- 使用{}
- 使用dict()函数
- 空字典
- 字典元素的查、增、删、改操作
- 字典元素的查找
- 使用[]
- 使用get()方法
- [] 和 get()区别
- in 和 not in
- 字典遍历
- 字典的增加
- 字典的删除
- 字典的修改
- 字典生成式
- 内置zip()函数
什么是字典
Python
内置了字典:dict
的支持,dict
全称dictionary
,在其他语言中也称为map
,使用键-值(key-value
)存储,具有极快的查找速度。
字典特点
- 字典中的所有元素都是一个
key-value
对,key
不允许重复,value
可以重复; - 字典中的元素是无序的;
- 字典中的
key
必须是不可变对象; - 字典也可以根据需要动态地伸缩;
- 字典会消费较大的内存,是一种使用
空间换时间
的数据结构;
和list列表对比
和list
比较,dict
有以下几个特点:
- 查找和插入的速度极快,不会随着
key
的增加而变慢; - 需要占用大量的内存,内存浪费多。
而list相反:
- 查找和插入的时间随着元素的增加而增加;
- 占用空间小,浪费内存很少。
所以,dict
是用空间来换取时间的一种方法。
字典原理
dict
可以用在需要高速查找的很多地方,在Python
代码中几乎无处不在,正确使用dict
非常重要,需要牢记的第一条就是dict
的key
必须是不可变对象。
因为dict
根据key
来计算value
的存储位置,如果每次计算相同的key
得出的结果不同,那dict
内部就完全混乱了。这个通过key
计算位置的算法称为哈希算法(Hash)
。
字典的创建
创建方式
注意:dict
作为 Python
的关键字和内置函数,变量名不建议命名为 dict
。
值可以取任何数据类型,但键必须是不可变的,如字符串,数字或元组都不能作为键。
使用{}
字典的每个键值 key=>value
对用冒号 :
分割,每个键值对之间用逗号 ,
分割,整个字典包括在花括号 {}
中。
'''使用{}创建字典'''
scores={'张三':100,'李四':98,'王五':45}
print(scores) # {'张三': 100, '李四': 98, '王五': 45}
print(type(scores)) # <class 'dict'>
使用dict()函数
也可以使用内置函数dict()
进行创建。
'''第二种创建dict()'''
student=dict(name='jack',age=20)
print(student) # {'name': 'jack', 'age': 20}
空字典
空的花括号代表空的dict
。
'''空字典'''
d={}
print(d) # {}
字典元素的查、增、删、改操作
字典包含多个 key-value
对,而 key
是字典的关键数据,因此程序对字典的操作都是基于 key
的。
字典元素的查找
通过 key 访问 value 。
使用[]
通过 key
访问 value
使用的也是方括号语法,就像列表和元组一样,只是此时在方括号中放的是 key
,而不是列表或元组中的索引。
'''获取字典的元素'''
scores={'张三':100,'李四':98,'王五':45}
'''第一种方式,使用[]'''
print(scores['张三']) # 100
使用get()方法
另一种获取元素的方法是内置函数get()
。
scores={'张三':100,'李四':98,'王五':45}
'''第二种方式,使用get()方法'''
print(scores.get('张三')) # 100
print(scores.get('陈六')) # None
print(scores.get('麻七',99)) #99是在查找'麻七'所对的value不存在时,提供的一个默认值
[] 和 get()区别
-
[]
如果字典中不存在指定的key
,抛出KeyError
异常。
scores={'张三':100,'李四':98,'王五':45}
'''第一种方式,使用[]'''
print(scores['张三'])
#print(scores['陈六']) # KeyError: '陈六'
-
get()
方法取值,如果字典中不存在指定的key
,并不会抛出KeyError
而是返回None
,可以通过参数设置默认的value
,以便指定的key
不存在时会返回数值。
scores={'张三':100,'李四':98,'王五':45}
print(scores.get('麻七',99)) #99是在查找'麻七'所对的value不存在时,提供的一个默认值
in 和 not in
如果要确定字典中是否存在指定的项,请使用 in
或者 not in
关键字:
-
in
:指定的key
在字典中存在返回True
; -
not in
: 指定的key
在字典中不存在返回True
;
'''key的判断'''
scores={'张三':100,'李四':98,'王五':45}
print('张三' in scores) # True
print('张三' not in scores) # False
字典遍历
-
keys()
: 获取字典中所有的key
; -
values()
: 获取字典中所有的value
; -
items()
: 获取字典中所有key
,value
对;
scores={'张三':100,'李四':98,'王五':45}
#获取所有的key
keys=scores.keys()
print(keys) # dict_keys(['张三', '李四', '王五'])
print(type(keys)) # <class 'dict_keys'>
#将所有的key组成的视图转成列表
print(list(keys)) # ['张三', '李四', '王五']
#获取所有的value
values=scores.values()
print(values) # dict_values([100, 98, 45])
print(type(values)) # <class 'dict_values'>
print(list(values)) # [100, 98, 45]
#获取所有的key-value对
items=scores.items()
print(items) # dict_items([('张三', 100), ('李四', 98), ('王五', 45)])
print(list(items)) # [('张三', 100), ('李四', 98), ('王五', 45)]
scores={'张三':100,'李四':98,'王五':45}
#字典元素的遍历
for item in scores:
print(item,scores[item],scores.get(item))
字典的增加
scores={'张三':100,'李四':98,'王五':45}
scores['陈六']=98 #新增元素
print(scores) # {'张三': 100, '李四': 98, '王五': 45, '陈六': 98}
字典的删除
scores={'张三':100,'李四':98,'王五':45}
del scores['张三'] #删除指定的key-value对
print(scores) # {'李四': 98, '王五': 45}
scores.clear() #清空字典的元素
print(scores) # {}
字典的修改
scores={'张三':100,'李四':98,'王五':45}
scores['陈六']=100 #修改元素
print(scores) # {'张三': 100, '李四': 98, '王五': 45, '陈六': 100}
字典生成式
内置zip()函数
用于将可迭代的对象作为参数,将对象中对应的元素打包成一个元组,然后返回由这些元组组成的列表。
items=['Fruits','Books','Others']
prices=[96,78,85,100,120]
d={item.upper():price for item ,price in zip(items,prices) }
print(d) # {'FRUITS': 96, 'BOOKS': 78, 'OTHERS': 85}