字典的简单介绍python
字典(dict)是python中惟⼀的⼀个映射类型.他是以{ }括起来的键值对组成.linux
在dict中key是 惟⼀的.在保存的时候, 根据key来计算出⼀个内存地址. 而后将key-value保存在这个地址中.算法
这种算法被称为hash算法, 因此, 切记, 在dict中存储的key-value中的key必须是可hash的, 若是你搞不懂什么是可哈希, 暂时能够这样记,ide
能够改变的都是不可哈希的, 那么可哈希就意味着不可变. 这个是为了能准确的计算内存地址⽽规定的.spa
已知的可哈希(不可变)的数据类型: int, str, tuple, bool 不可哈希(可变)的数据类型: list, dict, setcode
语法:{'key1':1,'key2':2}对象
注意: key必须是不可变(可哈希)的. value没有要求.能够保存任意类型的数据blog
# 合法 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 = {} dic['name'] = '汪峰' dic['age'] = 18 print(dic) 结果: {'name': '汪峰', 'age': 18} # 若是dict中没有出现这个key,就会将key-value组合添加到这个字典中 # 若是dict中没有出现过这个key-value. 能够经过setdefault设置默认值 s1 = dic.setdefault('王菲') print(s1) print(dic) 结果: None # 返回的是添加进去的值 {'王菲': None} # 咱们使用setdefault这个方法 里边放的这个内容是咱们字典的健,这样咱们添加出来的结果 就是值是一个None dic.setdefault('王菲',歌手) # 这样就是不会进行添加操做了,由于王菲在dic这个字典中存在 # 总结: 当setdefault中第一个参数存在这个字典中就就不进行添加操做,不然就添加 dic1 = {} s2 = dic1.setdefault('王菲','歌手') print(s2) print(dic1) 结果: 歌手 {'王菲': '歌手'}
删
dic = {'剑圣':'易','哈啥给':'剑豪','大宝剑':'盖伦'} s = dic.pop('哈啥给') # pop删除有返回值,返回的是被删的值 print(s) print(dic) # 打印删除后的字典 dic.popitem() # 随机删除 python3.6是删除最后一个 print(dic) dic.clear() # 清空
改
dic = {'剑圣':'易','哈啥给':'剑豪','大宝剑':'盖伦'} dic['哈啥给'] = '剑姬' # 当哈啥给是字典中的健这样写就是修改对应的值,若是不存在就是添加 print(dic) dic.update({'key':'v','哈啥给':'剑姬'}) # 当update中的字典里没有dic中键值对就添加到dic字典中,若是有就修改里边的对应的值 print(dic)
查
dic = {'剑圣':'易','哈啥给':'剑豪','大宝剑':'盖伦'} s = dic['大宝剑'] #经过健来查看,若是这个健不在这个字典中.就会报错 print(s) s1 = dic.get('剑圣') #经过健来查看,若是这个健不在这个字典中.就会返回None print(s1) s2 = dic.get('剑姬','没有还查你是否是傻') # 咱们能够在get查找的时候本身定义返回的结果 print(s2)
练习
dic = {'k1': "v1", "k2": "v2", "k3": [11,22,33]} 请在字典中添加一个键值对,"k4": "v4",输出添加后的字典 请在修改字典中 "k1" 对应的值为 "alex",输出修改后的字典 请在k3对应的值中追加一个元素 44,输出修改后的字典 请在k3对应的值的第 1 个位置插入个元素 18,输出修改后的字典
其余操做
key_list = dic.keys() print(key_list) 结果: dict_keys(['剑圣', '哈啥给', '大宝剑']) # 一个高仿列表,存放的都是字典中的key value_list = dic.values() print(value_list) 结果: dict_values(['易', '剑豪', '盖伦']) #一个高仿列表,存放都是字典中的value key_value_list = dic.items() print(key_value_list) 结果: dict_items([('剑圣', '易'), ('哈啥给', '剑豪'), ('大宝剑', '盖伦')]) # 一个高仿列表,存放是多个元祖,元祖中第一个是字典中的键,第二个是字典中的值
练习
循环打印字典的值
循环打印字典的键
循环打印元祖形式的键值对
dic = {'剑圣':'易','哈啥给':'剑豪','大宝剑':'盖伦'} for i in dic: print(i) 结果: 易 剑豪 盖伦 for i in dic.keys(): print(i) 结果: 易 剑豪 盖伦
dic = {'剑圣':'易','哈啥给':'剑豪','大宝剑':'盖伦'} for i in dic: print(dic[i]) 结果: 易 剑豪 盖伦 for i in dic.values(): print(i) 结果: 易 剑豪 盖伦
dic = {'剑圣':'易','哈啥给':'剑豪','大宝剑':'盖伦'} for i in dic.items(): print(i) 结果: ('剑圣', '易') ('哈啥给', '剑豪') ('大宝剑', '盖伦')
解构
a,b = 1,2 print(a,b) 结果: 1 2 a,b = ('你好','世界') print(a,b) 结果: 你好 世界 a,b = ['你好','大飞哥'] print(a,b) 结果: 你好 世界 a,b = {'汪峰':'北京北京','王菲':'天后'} print(a,b) 结果: 汪峰 王菲
循环字典获取键和值
for k,v in dic.items(): print('这是键',k) print('这是值',v) 结果: 这是键 剑圣 这是值 易 这是键 哈啥给 这是值 剑豪 这是键 大宝剑 这是值 盖伦
dic = { 'name':'汪峰', 'age':48, 'wife':[{'name':'国际章','age':38}], 'children':['第一个熊孩子','第二个熊孩子'] }
获取汪峰的妻子名字
d1 = dic['wife'][0]['name'] print(d1)
获取汪峰的孩子们
d2 = dic['children'] print(d2)
获取汪峰的第一个孩子
d3 = dic['children'][0] print(d3)
练习
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删除
set集合是python的⼀个基本数据类型. ⼀般不是很常⽤. set中的元素是不重复的.⽆序的.⾥ ⾯的元素必须是可hash的(int, str, tuple,bool), 咱们能够这样来记. set就是dict类型的数据但 是不保存value, 只保存key. set也⽤{}表⽰
注意: set集合中的元素必须是可hash的, 可是set本⾝是不可hash得.set是可变的.
set1 = {'1','alex',2,True,[1,2,3]} # 报错 set2 = {'1','alex',2,True,{1:2}} # 报错 set3 = {'1','alex',2,True,(1,2,[2,3,4])} # 报错
set中的元素是不重复的, 且⽆序的.
s = {"周杰伦", "周杰伦", "周星星"} print(s) 结果: {'周星星', '周杰伦'}
使⽤这个特性.咱们可使⽤set来去掉重复
# 给list去重复 lst = [45, 5, "哈哈", 45, '哈哈', 50] lst = list(set(lst)) # 把list转换成set, 而后再转换回list print(lst)
set集合增删改查
增长
s = {"刘嘉玲", '关之琳', "王祖贤"} s.add("郑裕玲") print(s) s.add("郑裕玲") # 重复的内容不会被添加到set集合中 print(s) s = {"刘嘉玲", '关之琳', "王祖贤"} s.update("麻花藤") # 迭代更新 print(s) s.update(["张曼⽟", "李若彤","李若彤"]) print(s)
删除
s = {"刘嘉玲", '关之琳', "王祖贤","张曼⽟", "李若彤"} item = s.pop() # 随机弹出⼀个. print(s) print(item) s.remove("关之琳") # 直接删除元素 # s.remove("⻢⻁疼") # 不存在这个元素. 删除会报错 print(s) s.clear() # 清空set集合.须要注意的是set集合若是是空的. 打印出来是set() 由于要和 dict区分的. print(s) # set()
修改
# set集合中的数据没有索引. 也没有办法去定位⼀个元素. 因此没有办法进⾏直接修改. # 咱们能够采⽤先删除后添加的⽅式来完成修改操做 s = {"刘嘉玲", '关之琳', "王祖贤","张曼⽟", "李若彤"} # 把刘嘉玲改为赵本⼭ s.remove("刘嘉玲") s.add("赵本⼭") print(s)
查询
# set是⼀个可迭代对象. 因此能够进⾏for循环 for el in s: print(el)
常⽤操做
s1 = {"刘能", "赵四", "⽪⻓⼭"} s2 = {"刘科⻓", "冯乡⻓", "⽪⻓⼭"} # 交集 # 两个集合中的共有元素 print(s1 & s2) # {'⽪⻓⼭'} print(s1.intersection(s2)) # {'⽪⻓⼭'} # 并集 print(s1 | s2) # {'刘科⻓', '冯乡⻓', '赵四', '⽪⻓⼭', '刘能'} print(s1.union(s2)) # {'刘科⻓', '冯乡⻓', '赵四', '⽪⻓⼭', '刘能'} # 差集 print(s1 - s2) # {'赵四', '刘能'} 获得第⼀个中单独存在的 print(s1.difference(s2)) # {'赵四', '刘能'} # 反交集 print(s1 ^ s2) # 两个集合中单独存在的数据 {'冯乡⻓', '刘能', '刘科⻓', '赵四'} print(s1.symmetric_difference(s2)) # {'冯乡⻓', '刘能', '刘科⻓', '赵四'} s1 = {"刘能", "赵四"} s2 = {"刘能", "赵四", "⽪⻓⼭"} # ⼦集 print(s1 < s2) # set1是set2的⼦集吗? True print(s1.issubset(s2)) # 超集 print(s1 > s2) # set1是set2的超集吗? False print(s1.issuperset(s2))
set集合本⾝是能够发⽣改变的. 是不可hash的. 咱们可使⽤frozenset来保存数据. frozenset是不可变的. 也就是⼀个可哈希的数据类型
s = frozenset(["赵本⼭", "刘能", "⽪⻓⼭", "⻓跪"]) dic = {s:'123'} # 能够正常使⽤了 print(dic)
这个不是很常⽤. 了解⼀下就能够了