字典描述:
字典是另一种可变容器模型,且可以存储任意类型对象。
字典的每个键值(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