字典
列表可以存储大量的数据类型,但是只能按照顺序存储,数据与数据之间关联性不强。
所以咱们需要引入一种容器型的数据类型,解决上面的问题,这就需要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没有要求.可以保存任意类型的数据
1.为什么要学习字典
- 存储数据比较大
- 字典的查找速度比列表快
- 方便查找
2.基本格式
dic = {"键":"值"}
键是唯一的
不可变数据类型才能作为字典的键
字典是无序的,可变的
# 例如
dic = {"123":1,2:"alex",False:[12,34],(1,2):"wusir"}
3.字典的基本操作
# 增
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