字典也是开发过程中最常用的一种数据类型。如果需要存储一个班学生的信息,每个学生有姓名、性别、年龄、住址等等的信息,如果用列表存储,需要很多列表。这时候就需要用字典来定义了。字典,dict,dictionary。
names = ['Amy','Lily','Ben'] infos = [[18,'female','北京'],[17,'female','天津'],[21,'male','上海']]
1、字典定义
字典是一种key-value的数据类型,使用{}定义,每个值用“,”分开,key和value用“:”分隔。
如上述举例将一个班学生的信息可以写入一个字典中,学生的编号为key,学生的信息为value。
1 infos = { 2 'Amy':[18,'female','北京'], 3 'Lily':[17,'female','天津'], 4 'Ben':[21,'male','上海'] 5 } 6 print(infos['Amy'])
字典的特点:
(1) 取数据方便
(2) 查找速度快
为什么字典查找的速度快呢?
如果用列表存储班级学生信息,那么需要查询一个学生信息时,需要先从names中找到他的位置,再从infos中找到他的信息,如果列表越长,查询速度会越慢。
用字典实现的话,只需要一个名字和信息对应的一个表,这样很快能根据名字找到它对应的信息,无论表有多大,查找速度都不会慢。
这和查字典是一样的。如果查一个字,是从第一页翻到最后一页,那么字典约大,查询速度越慢,这种方法就是在list中查找元素的方法。另一种方法是在字典的索引里找到字的对应页码,然后直接翻到那一页找到字,无论找哪个字都很快,不会随着字典变大而变慢,这就是字典的实现方式。
字典的特性:
(1) 字典是无续的,因为它没有下标,用key来当索引。
(2) 字典的key必须是唯一的,key不能重复,天生去重。
2、字典操作
(1) 增加:赋值,setdefault()
1 infos = { 2 'Amy':[18,'female','北京'], 3 'Lily':[17,'female','天津'], 4 'Ben':[21,'male','上海'] 5 } 6 infos['Kevin'] = [19,'male','北京'] #通过赋值增加 7 infos.setdefault('Heby',[18,'female','上海']) #通过setdefault增加 8 print(infos) 9 infos['Kevin'] = [19,'male','西安'] #如果key存在,会修改原来key对应的value 10 infos.setdefault('Amy',[18,'female','西安']) #如果key存在,不会修改原来key对应的value 11 print(infos)
(2) 删除:pop(),popitem(),del, clear()
1 infos = { 2 'Amy':[18,'female','北京'], 3 'Lily':[17,'female','天津'], 4 'Ben':[21,'male','上海'] 5 } 6 infos.pop('Lily') #指定key来删除 7 infos.popitem() #随机删除一个key,不常用 8 del infos['Ben'] #指定key来删除 9 infos.clear() #清空字典 10 print(infos)
(3) 修改:赋值
1 infos = { 2 'Amy':[18,'female','北京'], 3 'Lily':[17,'female','天津'], 4 'Ben':[21,'male','上海'] 5 } 6 infos['Ben'] = [19,'male','西安'] 7 print(infos)
(4) 查找:get(), 直接取值
1 infos = { 2 'Amy':[18,'female','北京'], 3 'Lily':[17,'female','天津'], 4 'Ben':[21,'male','上海'] 5 } 6 'Amy' in infos #判断Amy是否在字典中,返回True或False 7 print(infos.get('Lily')) 8 print(infos.get('Lucy')) #如果取不到这个key,返回None 9 print(infos.get('Lucy',110)) #如果取不到这个key,默认是110 10 print(infos['Ben']) 11 print(infos['Kevin']) #如果key不存在会报错
3、字典内置方法
keys(), values(), items(), get(), setdefault(), update()
1 infos = { 2 'Amy':[18,'female','北京'], 3 'Lily':[17,'female','天津'], 4 'Ben':[21,'male','上海'] 5 } 6 infos2 = {'Kevin':[19,'male','上海']} 7 print(infos.keys()) #获取到字典所有的keys 8 print(infos.values()) #获取到字典所有的values 9 print(infos.items()) # 获取字典所有的k-v 10 print(infos.get('Amy')) 11 print(infos.setdefault('Ben',[21,'male','上海'])) 12 infos.update(infos2) #更新字典值,如果key存在的话,就更新,不存在的话就添加 13 print(infos)
4、多重字典
1 infos = { 2 'Amy':{ 3 'age':18, 4 'money':200000, 5 'clothes':'100套', 6 'hzp':'n多', 7 'shoes':['nike','addis','lv','chanle'] 8 }, 9 'Lily':{ 10 '金库':'2000w', 11 'house':['三环一套','4环2套'], 12 'cars': { 13 'japan':['普拉多','兰德酷路泽'], 14 'usa':['林肯','凯迪拉克','福特'], 15 'china':['五菱宏光','qq','红旗'] 16 } 17 } 18 } 19 infos['Lily']['cars']['usa'].append('牧马人') 20 infos['Amy']['shoes'].append('匡威') 21 infos['Amy']['money'] = infos['Amy']['money'] +200 22 print(infos)
5、字典的循环
直接循环一个字典的话,那么循环的是字典的key
1 infos = { 2 'Amy':[18,'female','北京'], 3 'Lily':[17,'female','天津'], 4 'Ben':[21,'male','上海'] 5 } 6 for key in infos: 7 print(key,'-->',infos[key])#打印key和value的值,推荐使用这种方式,速度快 8 9 for k,v in infos.items(): 10 print(k,'===>',v)#打印key和value的值,这种方式不推荐,因为会把字典转换成列表,效率不高