05. 万恶之源-基本数据类型(dict)
本节主要内容:
- 字典的简单介绍
- 字典增删改查和其他操作
- 字典的嵌套
一. 字典的简单介绍
字典(dict)是python中唯 一的 一个映射类型.他是以{ }括起来的键值对组成. 在dict中key是唯 一的. 在保存的时候, 根据key来计算出 一个内存地址. 然后将key-value保存在这个地址中.
这种算法被称为hash算法, 所以, 切记, 在dict中存储的key-value中的key'必须是可hash的,
如果你搞不懂什什么是可哈希, 暂时可以这样记, 可以改变的都是不可哈希的,那么可哈希就意味着不可变. 这个是为了了能准确的计算内存地址 而规定的.
已知的可哈希(不可变)的数据类型: int, str, tuple, bool
不可哈希(可变)的数据类型: list, dict, set
语法 :
{key1: value1, key2: value2....}
注意: key必须是不可变(可哈希)的. value没有要求.可以保存任意类型的数据
# 合法
dic = {123: 456, True: 999, "id": 1, "name": 'sylar', "age": 18, "stu": ['帅
哥', '美 女女'], (1, 2, 3): '麻花藤'}
print(dic[123])
print(dic[True])
print(dic['id'])
print(dic['stu'])
print(dic[(1, 2, 3)])
# 不不合法
# dic = {[1, 2, 3]: '周杰伦'} # list是可变的. 不不能作为key
# dic = {{1: 2}: "哈哈哈"} # dict是可变的. 不不能作为key
dic = {{1, 2, 3}: '呵呵呵'} # set是可变的, 不不能作为key
dict保存的数据不是按照我们添加进去的顺序保存的. 是按照hash表的顺序保存的. 而hash表不是连续的. 所以不能进 行行切片 工作. 它只能通过key来获取dict中的数据
二. 字典的增删改查和其他相关操作
1. 增加
dic = {} |
||
dic['name'] = '周润发' |
# 如果dict中没有出现这个key, 就会新增 一个key-value的组 |
|
合进dict |
||
dic['age'] = 18 |
||
print(dic) |
||
# 如果dict中没有出现过这个key-value. 可以通过setdefault设置默认值 |
||
dic.setdefault('李李嘉诚') |
# 也可以往 里里 面设置值. |
|
dic.setdefault("李李嘉诚", |
"房地产") |
# 如果dict中已经存在了了. 那么setdefault将不不会 |
起作 用 |
||
print(dic) |
||
2. 删除
ret = dic.pop("jay") print(ret)
del dic["jay"] print(dic)
# 随机删除. ret = dic.popitem()
# 清空字典中的所有内容 dic.clear()
3. 修改
dic = {"id": 123, "name": 'sylar', "age": 18}
dic1 = {"id": 456, "name": "麻花藤", "ok": "wtf"} dic.update(dic1) # 把dic1中的内容更更新到dic中. 如果key重名. 则修改替换. 如果不不存在key, 则新增. print(dic)
print(dic1)
4. 查询
查询 一般 用key来查找具体的数据.
print(dic['name'])
# print(dic['sylar']) # 报错 print(dic.get("ok"))
print(dic.get("sylar")) |
# None |
|
print(dic.get("sylar", " 牛B")) |
# 牛B |
|
5. 其他相关操作
dic = {"id": 123, "name": 'sylar', "age": 18, "ok": "科 比"}
print(dic.keys()) # dict_keys(['id', 'name', 'age', 'ok']) 不不 用管它是什什么.当
成list来 用就 行行
for key in dic.keys():
print(key)
print(dic.values()) # dict_values([123, 'sylar', 18, '科 比']) 一样. 也当
list来 用
for value in dic.values(): print(value)
print(dic.items()) # dict_items([('id', 123), ('name', 'sylar'), ('age', 18), ('ok', '科 比')]) 这个东 西也是list. 只不不过list中装的是tuple for key, value in dic.items(): # ?? 这个是解构
print(key, value)
# 解构 a, b = 1, 2
print(a, b)
(c, d) = 3, 4 print(c, d)
e, f = [1, 2, 3] # 解构的时候注意数量量必须匹配 print(e, f)
三. 字典的嵌套
# 字典的嵌套 dic1 = {
"name": "汪峰",
"age": 18,
"wife": {
"name": '章 子怡',
"age": 28
},
"children": ['第 一个 毛孩 子', '第 二个 毛孩 子'],
"desc": '峰哥不不会告我吧. 没关系. 我想上头条的'
}
print(dic1.get("wife").get("name"))
print(dic1.get("children")) print(dic1.get("children")[1])
练习:
dic1 = { 'name':['alex',2,3,5], 'job':'teacher',
'oldboy':{'alex':['python1','python2',100]}
}
1,将name对应的列列表追加 一个元素’wusir’。
2,将name对应的列列表中的alex 首字 母 大写。
3,oldboy对应的字典加 一个键值对’ 老老男孩’,’linux’。
4,将oldboy对应的字典中的alex对应的列列表中的python2删除。
#字典增删改查
# dic = {'jay':"周杰伦", "jj":"林俊杰", "eason":"陈奕迅"}
# print(dic)
# dic = {1: "马化腾", False:"阿里巴巴", "sylar":"帅的不行不行的", (1, "哈哈"): "元组", ["吼吼"]:"列表"}
# #注意列表是可变的!
# print(dic)
# 字典的相关操作
# 增加
# dic = {"昆凌":"周杰伦的老婆"}
# dic['国际章'] = "汪峰的老婆" # 新增
# dic['国际章'] = "雄壮的老外" # 如果key重复了. 会替换掉原来的value
#
# # dic.setdefault("马蓉", "王宝强的前任老婆")
# print(dic)
# # dic.setdefault("马蓉", "宋哲的现任老婆????") # 如果字典中已经包含了这个key. 不再继续保存
# print(dic)
#
# dic = {"牌牌":"你去哪里了", "晓雪":"你快回来.", "雪雪": "又走了"}
# # ret = dic.pop("晓雪") # 删除一个元素. 返回这个元素的value值
# # print(ret)
#
# del dic["雪雪"]
# ret = dic.popitem() # 随机删除,返回给你的是一个元组.
#
# print(ret)
# print(dic)
# dic = {"id":1, 'name':'李嘉诚', 'money':10000000}
# # 李嘉诚赔了500
# dic['money'] = dic['money'] - 500 # 用key去修改
# print(dic)
# dic1 = {"李晨":"范冰冰", "邓超":"孙俪", "王祖蓝":"李亚男"}
# dic2 = {"李晨":"张馨予", "郑凯":"baby", "王宝强":"马蓉"}
# dic1.update(dic2) # 把dic2中的内容更新到 dic1 , 如果存在了key. 替换. 如果不存在,添加
# print(dic1)
# print(dic2)
# dic = {"及时雨":"宋江", "小李广":"花荣", "黑旋风":"李逵", "易大师":"剑圣"}
# dic["大宝剑"] = "盖伦" # 新增
# dic["及时雨"] = "天老爷" # 修改
# print(dic["易大师是个脑残"]) # 查询, 如果key不存在,报错
# print(dic.get("易大师", "余小C")) # 如果key不存在. 返回None,我们可以改为返回默认值"余小C"
# get()# 查询好用的一笔
# get可以通过key来获取value的值. 那么如果key不存在. 返回None.
# get可以给出一个默认值. 当key不存在的时候返回默认值
# dic = {"及时雨":"宋江", "易大师":"剑圣"}
# # dic.setdefault("及时雨", "诺克萨斯") # 第一可以帮我们添加,前提条件没有相同的KEY
# # print(dic)
# ret = dic.setdefault("及时雨123", "hello")
# print(ret)
# print(dic)
##setdefault
# 1. 首先判断原来的字典中有没有这个key . 如果没有. 执行新增
# 2. 用这个key去字典中查询, 返回查到的结果
# dic = {"及时雨":"宋江", "易大师":"剑圣"}
# ret = dic.setdefault("潘金莲", "西门庆")
# # print(dic) #
# # print(ret) # 西门庆
# ret1 = dic.setdefault("及时雨", "西门庆")
# print(dic) #
# print(ret1) #宋江
#字典的常用操作
dic = {"及时雨":"宋江", "易大师":"剑圣", "维恩":"暗影猎手"}
# print(dic.keys()) # 拿到所有的key, 返回key的集合. 像是列表. 但是不是列表
#
# for key in dic.keys(): # 高仿列表哈,可以进行迭代循环
# print(key)
#
# print(dic.values())
# for value in dic.values():# 高仿列表哈,可以进行迭代循环
# print(value)
# dic = {"及时雨":"宋江", "易大师":"剑圣", "维恩":"暗影猎手"}
print(dic.items()) # (重点)拿到键值对,每一项是元组
# # 遍历dict
# for item in dic.items():
# print(item[0])
# for item in dic.items():
# print(item[1])
#
# for k, v in dic.items():
# print(k , v)
# for k, v in dic.items():
# # = item # (key, value)
# # print(item) # (key, value)
# print(k,v)
# a,b=1,2
# print(a)
# print(b)
# a=1,2
# print(a)
# a,b = (1,2)
# print(a)
# 解构 . 解包
# a, b = (1, 2)
# print(a)
# print(b)
# a, b, c = ("马化腾", "马云", "马良")
# print(b)
# a, b = [1, 2]
# print(a, b)
#字典的嵌套
dic = {
"name":"汪峰",
"age": 58,
"wife":{
"name":"国际章",
"salary": 180000,
"age": 37
},
"children":[
{"name":"老大", "age": 18},
{"name":"老二", "age": 118}
]
}
print(dic["children"][1]["age"])
print(dic["wife"]['salary'])
#字典的for循环
dic = {1: 'a', 2:'b', 3:'c'}
for a in dic: # 直接循环字典.拿到的是key
print(a)#key
print(dic[a])#value