本节主要内容:
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中的数据
# 合法 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
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])
1. list 列表. 用[]表示. 有索引下标. 切片
2. 增删改查
1.增加: append(), insert(), extend()
2.删除: pop(), remove(), del list[], clear()
3.修改: 索引切片修改
4.查询: for循环
3. 常用操作:
1. count()计数
2. len() 求长度 __len__()
3. sort() 排序 reverse = True 倒序
4. reverse() 顺序翻转 [::-1]
4. 嵌套
降维操作
5. 元组
tuple, 只读列表. 不能修改. 不能修改的是元组内部第一层元素
6. range(5, 10, 2)
二. 作业讲解
三. 今日主要内容
1. dict
用大括号{} 括起来. 内部使用key:value的形式来保存数据
{‘jay‘:‘周杰伦‘, "jj":‘林俊杰‘}
注意:字典的key必须是可哈希的. 不可变的, value 没有限制
不是按照我们保存的顺序保存的, 无序的
2. 增删改查
1. dict[不存在的key] = value, setdefault()
2. pop(key). del dict[key]. popitem(), clear()
3. dict[存在的key] = 新值, d1.update(d2) 把d2的k-v更新到d1中
4. get(key, 默认值), setdefault(), dict[key]
3. 字典的常用方法
1. keys() 返回所有字典的key的集合(高仿列表)
2. values() 返回所有的value的集合
3. items() 返回键值对. 元组
解构:
a, b = (1, 2)
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‘])
原文:https://www.cnblogs.com/zhao110/p/9309583.html