本节主要内容:
1. 字典的简单介绍
2. 字典增删改查和其他操作
3. 字典的嵌套
一. 字典的简单介绍
字典(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']) # 报错
rint(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])
三. 字典的遍历
遍历字典: keys() 、values() 、items()
1. xxx.keys() : 返回字典的所有的key 返回一个序列,序列中保存有字典的所有的键
效果图:

代码:
|
1 2 3 4 5 6 7 8 |
|
2. xxx.values() : 返回字典所有的值
效果图:

代码:
|
1 2 3 4 5 |
|
3. xxx.items() : 返回字典中所有的key = values 返回一个序列,序列中包含有双值子序列
效果图:

代码:
|
1 2 3 4 5 6 7 8 9 |
|
练习:
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删除。
本文介绍了Python字典的基本概念,包括字典的创建、键值对的增删改查操作,强调了键必须是可哈希的。还详细讲解了字典的嵌套使用,并提供了相关操作示例,如字典的遍历和解构。此外,文章提到了字典遍历的方法,包括keys()、values()和items()的用法。

被折叠的 条评论
为什么被折叠?



