列表可以存储大量的数据类型,但是只能按照顺序存储,数据与数据之间关联性不强。
所以咱们需要引入一种容器型的数据类型,解决上面的问题,这就需要dict字典。
字典(dict)是python中唯?的?个映射类型.他是以{ }括起来的键值对组成.
在dict中key是 唯?的.在保存的时候, 根据key来计算出?个内存地址. 然后将key-value保存在这个地址中.
这种算法被称为hash算法, 所以, 切记, 在dict中存储的key-value中的key必须是可hash的
可以改变的都是不可哈希的, 那么可哈希就意味着不可变. 这个是为了能准确的计算内存地址?规定的.
已知的可哈希(不可变)的数据类型: int, str, tuple, bool 不可哈希(可变)的数据类型: list, dict, set
语法:{'key1':1,'key2':2}
注意: key必须是不可变(可哈希)的. value没有要求.可以保存任意类型的数据
dic = {"键":"值"}
键是唯一的
不可变数据类型才能作为字典的键
字典是无序的,可变的
# 例如
dic = {"123":1,2:"alex",False:[12,34],(1,2):"wusir"}
# 增
dic[3] = "233"
dic.setdefault(键,默认值)
print(dic.setdefault(键,默认值)) #打印出来的是值
# 删
dic.pop(键)
dic.clear() # 清空字典
del dic[键] #删除该键值对
# 改
dic[键]=值
dic.update()
# 查
dic["键"]
dic.get("键","找不到时返回设定的默认值")
# 其他操作
dic.keys() # 取出字典中所有的键
dic.values() # 取出字典中的所有的值
dic.items() # 取出字典中的键值对,并以元组的形式存在列表中
#键值分离
for k,v in dic.items:
pring(k,v)
#字典支持嵌套使用
# 解构
a, b =[10, 20]
a = [1,2,3]
b = (3,2,1)
# 用一行代码将数值转换
a,b = b,a
print(a,b)
# 利用所学知识,将id前3位与字典中相对应的地区进行匹配,得出id中各属地出现的次数
# 得出结果形如:{"河南":3,"河北":2,"北京":1,"内蒙":1}
id = [120121198903119561,
120121198903110561,
120121196903119561,
130482198307144762,
130482198307144662,
110121197805144347,
150121197502122799]
addrs = {
120: "河南",
130: "河北",
110: "北京",
150: "内蒙",
}
# 方式一
dic = {}
for i in id:
addrs_key = int(str(i)[0:3])
dic_key = addrs[addrs_key]
if dic.get(dic_key):
dic[dic_key] +=1
else:
dic[dic_key] = 1
print(dic)
# 方式二
dic1 = {}
for i in id:
a = int(str(i)[0:3])
if dic1.get(addrs[a]):
dic1[addrs[a]] += 1
else:
dic1.setdefault(addrs[a], 1)
print(dic1)
# 方式三
dic1 = {}
for i in id:
dic1[addrs[int(str(i)[0:3])]] = dic1.get(addrs[int(str(i)[0:3])], 0) + 1
print(dic1)
# 将字符串s转变为形如{'key1': '1', 'key2': '2', 'key3': '3'}的字典
s = "key:1-key:2-key:3"
ls = s.split("-")
dic = {}
for i in ls:
k,v= (i.split(":"))
dic[k+f"{v}"]=v
print(dic)
测验
用你能想到的最少的代码生成一个包含100个key的字典,每个value的值不能一样
{‘k0’: 0, ‘k1’: 1, ‘k2’: 2, ‘k3’: 3, ‘k4’: 4, ‘k5’: 5, ‘k6’: 6, ‘k7’: 7, ‘k8’: 8, ‘k9’: 9} 请把这个dict中key大于5的值value打印出来。
把题2中value是偶数的统一改成-1
请设计一个dict, 存储你们公司每个人的信息, 信息包含至少姓名、年龄、电话、职位、工资,并提供一个简单的查找接口,用户按你的要求输入要查找的人,你的程序把查到的信息打印出来
# 下面解答仅个人观点
# 1
key = {}
for i in range(100):
key.setdefault(i,f"我是{i}")
print(key)
# 2 and 3
dic = {'k0': 0, 'k1': 1, 'k2': 2, 'k3': 3, 'k4': 4, 'k5': 5, 'k6': 6, 'k7': 7, 'k8': 8, 'k9': 9}
for k,v in dic.items():
if v > 5:
print(dic[k])
for k,v in dic.items():
if v % 2 == 0:
dic[k] = -1
print(dic)
# 4
dic = {"小明":[18,199,"销售",8000],
"小白":[20,110,"安全",9000]}
user_input = input("请输入你要查找的人的名字:")
for k in dic:
if k == user_input:
print(f"小明的年龄是{dic[k][0]},电话是{dic[k][1]},职业是{dic[k][2]},工资是{dic[k][3]}")
break
else:
print("查无此人")
break
原文:https://www.cnblogs.com/tianming66/p/11722146.html