数据类型——字典
1、优势:
相较于列表的优势,查询速度快,操作方便
2、dict定义:
{ key1:value1 , key2:value2 }
特性
1、key-value结构
2、key必须为不可变数据类型(字符串、数字)、必须唯⼀
3、可存放任意多个value、可修改、可以不唯⼀
4、⽆序, ordered_dict
5、查询速度快,且不受dict的⼤⼩影响,
一、操作
mes = { "乡村爱情" : ["尼古拉斯·赵四","男","打球"], "喜剧之王" : ["周星驰","男","奋斗"], "逃学威龙" : ["吴孟达","男","认真"] }
以下小标题中的mes使用以上数据
1、增加操作
# (新增/修改)操作,直接增加一个key:
mes["大话西游"] = ["孙悟空","石猴","担当"] # 当字典中存在key时,为修改,不存在则为增加
# 修改结果
# { "乡村爱情" : ["尼古拉斯·赵四","男","打球"],
# "喜剧之王" : ["周星驰","男","奋斗"],
# "逃学威龙" : ["吴孟达","男","认真"]
# "大话西游" : ["孙悟空","石猴","担当"]
# }
2、删除操作
mes.pop("乡村爱情") # 删除key:"乡村爱情",会返回删除掉的信息
# 此时的mes = {'喜剧之王': ['周星驰', '男', '奋斗'], '逃学威龙': ['吴孟达', '男', '认真']}
mes.clear() # 清空字典
# 此时的mes = {}
3、查询操作
# 查询操作:
print(mes["乡村爱情"]) # 按照关键词“乡村爱情”查找
print(mes.get("逃学威龙")) # 获取关键词“逃学威龙”对应的值
print("大话西游" in mes) # 判断是否存在关键词,且速度与数量无关:False
print(mes.keys()) # 输出字典mes的关键词列表:dict_keys(['乡村爱情', '喜剧之王', '逃学威龙'])
print(mes.values()) # 输出字典mes的值列表:dict_values([['尼古拉斯·赵四', '男', '打球'], ['周星驰', '男', '奋斗'], ['吴孟达', '男', '认真']])
# 循环取值方式1
for i in mes.items():
print(i)
# 结果:
# ('乡村爱情', ['尼古拉斯·赵四', '男', '打球'])
# ('喜剧之王', ['周星驰', '男', '奋斗'])
# ('逃学威龙', ['吴孟达', '男', '认真'])
# 循环取值方式2
for k,v in mes.items():
print(k,":",v) #
# 结果:
# 乡村爱情 : ['尼古拉斯·赵四', '男', '打球']
# 喜剧之王 : ['周星驰', '男', '奋斗']
# 逃学威龙 : ['吴孟达', '男', '认真']
# 循环取值方式3
for i in mes:
print(i,mes[i])
# 结果:
# 乡村爱情 ['尼古拉斯·赵四', '男', '打球']
# 喜剧之王 ['周星驰', '男', '奋斗']
# 逃学威龙 ['吴孟达', '男', '认真']
4、字典求长
print(len(mes)) # 3
5、字典嵌套
mes["乡村爱情"] = {"乡村爱情" : "赵四","性别":"男"}
print(mes)
# {'乡村爱情': {'乡村爱情': '赵四', '性别': '男'},
# '喜剧之王': ['周星驰', '男', '奋斗'],
# '逃学威龙': ['吴孟达', '男', '认真']}