上一篇说了整型、浮点型、列表和元组,这篇主要记录字典的学习。
字典和字典操作
字典也是开发过程中最常用的一种数据类型。如果需要存储一个班学生的信息,每个学生有姓名、性别、年龄、住址等等的信息,如果用列表存储,需要很多列表。这时候就需要用字典来定义了。字典,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 ininfos:7 print(key,'-->',infos[key])#打印key和value的值,推荐使用这种方式,速度快
8
9 for k,v ininfos.items():10 print(k,'===>',v)#打印key和value的值,这种方式不推荐,因为会把字典转换成列表,效率不高