万恶之源 - Python基础数据类型三
字典
字典的简单介绍
字典(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没有要求.可以保存任意类型的数据
- # 合法
- 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)
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)
这个不是很常⽤. 了解⼀下就可以了
万恶之源 - Python基础数据类型三的更多相关文章
- 万恶之源 - Python基础数据类型一
整数 整数在Python中的关键字用int来表示; 整型在计算机中运于计算和比较 在32位机器上int的范围是: -2**31-2**31-1,即-2147483648-2147483647 在64 ...
- 万恶之源 - Python基础
Python简介 python的创始人为吉多·范罗苏姆(Guido van Rossum).1989年的圣诞节期间,吉多·范罗苏姆(中文名字:龟叔)为了在阿姆斯特丹打发时间,决心开发一个新的脚本解释程 ...
- 万恶之源-python基本数据类型
万恶之源-基本数据类型(dict) 本节主要内容: 字典的简单介绍 字典增删改查和其他操作 3. 字典的嵌套 ⼀一. 字典的简单介绍 字典(dict)是python中唯⼀一的⼀一个映射类型.他是以{ ...
- 万恶之源 - Python基础知识补充
编码转换 编码回顾: 1. ASCII : 最早的编码. ⾥⾯有英⽂⼤写字⺟, ⼩写字⺟, 数字, ⼀些特殊字符. 没有中⽂, 8个01代码, 8个bit, 1个byte 2. GBK: 中⽂国标码, ...
- Python基础数据类型(三)list 列表
3.4列表list [] 列表的格式 lst_l = [1,'123',[1,'www',2],'包青天'] 列表也有索引 print(lst_l[0]) print([-1][0:2]) #包青 切 ...
- Python基础数据类型-列表(list)和元组(tuple)和集合(set)
Python基础数据类型-列表(list)和元组(tuple)和集合(set) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 本篇博客使用的是Python3.6版本,以及以后分享的 ...
- Python基础数据类型题
Python基础数据类型 题考试时间:三个小时 满分100分(80分以上包含80分及格)1,简述变量命名规范(3分) 1.必须是字母,数字,下划线的任意组合. 2.不能是数字开头 3.不能是pytho ...
- Python 入门之Python基础数据类型及其方法
Python 入门之Python基础数据类型 1. 整型:int 用于计算,用于比较 (在赋值的时候先执行等号右边的内容) 1.1 整数的加 a = 10 b = 20 print(a + b) 结果 ...
- Python基础数据类型-字符串(string)
Python基础数据类型-字符串(string) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 本篇博客使用的是Python3.6版本,以及以后分享的每一篇都是Python3.x版 ...
随机推荐
- PHP 中文字符串截取
$str = "abcdef啊啊吧啊"; function my_sub($str, $st ,$len){ $ret = ""; for( $st; $len ...
- 解决Sublime Text 3中文显示乱码问题(转)
解决Sublime Text 3中文显示乱码问题(转) 1.打开Sublime Text 3,按Ctrl+-打开控制行,复制粘贴以下python代码,然后回车运行. 2. 复制并粘贴如下代码: 2.重 ...
- artdialog5 bug
1.使用artdialog5时,使用两个输入框传值,一直无法取到值,使用简单的ID无法取到值,如id=branch..改为id=branch_str_dialog就可以了,问题是解决了,可是没有找到原 ...
- css笔记 - transform学习笔记(二)
transform转换 CSS transform 属于2D/3D上的转换.变形效果.他不是一个动画,他就是变形.比如正方形变平行四边形,再变圆形.都是形状变成另一个形状. 但是如果配合上transi ...
- NC 的高级应用
高级用法: (1)作攻击程序用,例子: 格式1:type.exe c:\exploit.txt|nc -nvv 192.168.x.x 80 格式2:nc -nvv 192.168.x.x 80 &l ...
- create-react-app项目中的eslint
"no-multi-spaces": 1, //禁止多个空格 "jsx-quotes": 1, //此规则强制在JSX属性中一致使用双引号或单引号 " ...
- backface-visibility 属性
图片img加了backface-visibility 属性, 图片变清晰, 原因不明 a,img{ backface-visibility:hidden; -webkit-backface-visib ...
- 应用程序创建自己的奔溃转储(crash dump)文件
1.注册自定义的UnhandledExceptionFilter,C/C++ Runtime Library下需要注意自定义handler被移除(hook kernel32.dll的SetUnhand ...
- 在jmeter测试中模拟不同的带宽环境
怎么去测试在手机app中和在web的不同的连接速度对服务器的影响呢? 大部分情况下,手机终端用户通过移动网络访问网站.所以在不同的网络连接数据下,我们的网站或程序可以同时处理多少链接?今天,这篇文件就 ...
- springMVC 几种页面跳转方式
今天主要写一下响应界面跳转的几种方式 1.在注解的方式中 1.1通过HttpServletResponse的API直接输出(不需要配置渲染器) controller类的主要代码 @Controller ...