字典描述:
字典是另一种可变容器模型,且可以存储任意类型对象。
字典的每个键值(key=>value)对用冒号分隔,每对之间用逗号分割,整个字典包括花括号在内,如下所示:
d={key1:value1,key2:value2}
键必须是唯一的,但值不必。
值可以取任何数据类型,但是键是必须不可变的,如字符串、元组或数字。
如:
d = {'Alex':'aaa','Wang':'bbb'}
d1={'Alex':111,'Wang':222}
访问字典的值:
d = {'Alex':'aaa','Wang':'bbb'}
#d1={'Alex':111,'Wang':222}
print(d.keys()) #读取字典所有键
print(d.values()) #读取字典所有值
print('d["Alex"]: ',d['Alex']) #读取某一个键的值,
# (习惯:引号使用,当需要使用叠加的引号时,注意不要都使用同一种引号。比如全部单引号或者全部双引号,那样会报错。) 比如:print('d[‘Alex’]: ',d['Alex'])
print("d['Alex1']: ",d['Alex1']) #读取不到键会报错,信息如下KeyError: 'Alex1'
运行结果:
print("d['Alex1']: ",d['Alex1'])
KeyError: 'Alex1'
dict_keys(['Alex', 'Wang'])
dict_values(['aaa', 'bbb'])
d['Alex']: aaa
增加&查找&删除&修改:
d = {
'1':'aaa',
'2':'bbb',
'3':'ccc',
"4":'ddd',
}
#d1={'Alex':111,'Wang':222}
d['5']='fff' #当查询不存在这个键时,就会添加。
print(d)
d['1']='111' #当查询存在这个键时,如果值不对就会修改该值。
print(d)
d2=d.get('5') #用get方法,找到不存在只会返回None,不会报错
print(d2)
#del d['1']#python内置的通用删除方法
#d.pop('2')#字典里的pop必须指定删除对象
d.popitem()
print(d)
d.clear() #清空字典
print(d)
运行结果:
{'1': 'aaa', '2': 'bbb', '3': 'ccc', '4': 'ddd', '5': 'fff'}
{'1': '111', '2': 'bbb', '3': 'ccc', '4': 'ddd', '5': 'fff'}
{'1': '111', '2': 'bbb', '3': 'ccc', '4': 'ddd'}
{}
注:
当查询的键不存在时,会默认添加。
get()查询某个键查询不到时,只会返回None,不会报错。
多级字典的嵌套及操作:
info ={
'NJ':{
'建邺区':['A','B','C'],
'江宁区':['AA','BB','CC'],
},
'SZ':{
'福田区':['1','2','3'],
'高新区':['11','22','33'],
}
}
print(info)
info['NJ']['建邺区'][2]=55 #可以修改键里面的值
print(info)
info.setdefault('JD',{'SSS':[1,2]}) #查不到的可以添加 key-value
print(info)
info.setdefault('SZ',{'SSS':[1,2]}) #无法修改 键对应的值
print(info)
运行结果:
{'NJ': {'建邺区': ['A', 'B', 'C'], '江宁区': ['AA', 'BB', 'CC']}, 'SZ': {'福田区': ['1', '2', '3'], '高新区': ['11', '22', '33']}}
{'NJ': {'建邺区': ['A', 'B', 55], '江宁区': ['AA', 'BB', 'CC']}, 'SZ': {'福田区': ['1', '2', '3'], '高新区': ['11', '22', '33']}}
{'NJ': {'建邺区': ['A', 'B', 55], '江宁区': ['AA', 'BB', 'CC']}, 'SZ': {'福田区': ['1', '2', '3'], '高新区': ['11', '22', '33']}, 'JD': {'SSS': [1, 2]}}
{'NJ': {'建邺区': ['A', 'B', 55], '江宁区': ['AA', 'BB', 'CC']}, 'SZ': {'福田区': ['1', '2', '3'], '高新区': ['11', '22', '33']}, 'JD': {'SSS': [1, 2]}}
其他操作:
d = {
'1':'aaa',
'2':'bbb',
'3':'ccc',
"4":'ddd',
}
a ={
'1':'111',
'd':123,
888:999,
}
d.update(a) #合并列表,并且以被合并的数据为最新的数据更新字典
print(d)
print(d.items()) #转换为列表
运行结果:
{'1': '111', '2': 'bbb', '3': 'ccc', '4': 'ddd', 'd': 123, 888: 999}
dict_items([('1', '111'), ('2', 'bbb'), ('3', 'ccc'), ('4', 'ddd'), ('d', 123), (888, 999)])
循环读取字典:
for key in d:
print(key,d[key])
for item,key in d.items(): #会先把dictionary转成list,数据里大时莫用
print(item,key)
运行结果:
1 aaa
2 bbb
3 ccc
4 ddd
1 aaa
2 bbb
3 ccc
4 ddd