元组/字典/集合内置方法+简单哈希表(day07整理)
二十三、元组内置方法
什么是元组:只可取,不可更改的列表
作用:元组一创建就被写死了
定义方式:()内用逗号隔开多个元素(可以为任意数据类型)
tup = tuple((1, 2, 3)) # 如果元组只有一个元素,必须要加逗号 tup = (1,)使用方法
索引取值
print(tuo[0]索引切片
print(tup[0:3])for循环
for i in tup: print(i)成员运算
print(0 in tup)len长度
print(len(tup))index
print(tup.index(1))count
print(tup.count(2))
有序or无序
有序
可变or不可变
没有可变不可变一说
二十四、字典数据类型
作用:存储多个数据、对每个数据都有描述
定义方式:{}内用括号隔开多个键key(具有描述意义,不能为可变类型)值value(任意数据类型)对
dic = {'name' = 1}使用方法
优先掌握
按key取值/按key修改值
dic = {'a' = 1, 'b' = 2, 'c' = 3} print(dic['a'])添加值(没有就添加,有就修改)
dic['d'] = 4for循环
for i in dic: print(i) # 打印的为key成员运算
print('a' in dic)len
print(len(dic))keys/values/items
print(dic.keys()) # 看成列表 print(dic.values()) # 获取所有值 for i, j in dic.items: print(i, j)
需要掌握
get
print(dic.get('b', 1)) # 字典中没有返回None,可以给定一个默认值update
dic1 = {'a':1, 'b':2} dic2 = {'c':3, 'd':4} dic1.update(dic2) print(dic1)fromkeys
print(dict.fromkeys(2)) # 默认给Nonesetdefault
dic.setdefault('j', 2) #字典有这个key,就不修改,没有则增加
有序or无序
无序
可变or不可变
可变
二十五 集合内置方法
作用
- 并集/交集/差集/补集
- 去重
- 乱序
定义方式
{}内隔开多个元素(不能为可变数据类型)
s = {} # 空字典 s = set() # 空集合 # 字符串比较,先比较第一位数字,在比较第二位使用方法
并集(|)
两个集合合并
交集(&)
两个集合共有
差集(-)
集合中去掉另一个集合中共有的
补集(^)
去掉的两个集合共有元素的合并集合
add
pythoners.add('oscar')remove和discard
pythoners.remove('oscar1') # 没有报错 pythoners.discard('oscar1') # 没有不报错 print(pythoners)pop
pythoners.pop() # 随机删除一个
有序or无序:无序
可变or不可变:可变
二十五、数据类型总结
- 存值个数
- 存一个值:整形/浮点型/字符串
- 存多个值:列表/元组/字典/集合
- 有序or无序
- 有序:字符串/列表/元组
- 无序:字典/集合
- 可变or不可变
- 可变:列表/字典/集合
- 不可变:整形/浮点型/字符串/元组
二十六、深浅拷贝
- 可变/不可变
- 可变:值变id不变
- 不可变:值变id变化
拷贝
lt1 = [1, 2, 3, [4, 5, 6]] lt2 = lt1lt2为lt1的拷贝对象,lt1内部的不可变数据变化,lt2变;lt1内部的可变数据变化,lt2变
浅拷贝
lt1 = [1, 2, 3] lt2 = copy.copy(lt1)当lt2为lt1的浅拷贝对象时,lt1内部的不可变元素变化时,lt2不变;lt1内部的可变元素变化,lt2变
深拷贝
lt1 = [1, 2, 3, [4, 5, 6]] lt2 = copy.deepcopy(lt1)当lt2是lt1的深拷贝对象时,lt1内部的不可变类型变化,lt2不变;lt1内部的可变类型变化,lt2不变
- 总结
- 当lt2为lt1的拷贝对象时,无论lt1内部元素是可变还是不可变,只要发生变化,lt2也会发生变化
- 当lt2为lt1的浅拷贝对象时,只有lt1内部的可变元素变化时lt2才会变
- 当lt2为lt1的深拷贝对象时,无论lt1内部元素是可变还是不可变元素,发生变化,lt2均不会变化
- 深浅拷贝只针对可变数据类型,因为,如果是深浅拷贝对象时不可变数据,无论深浅拷贝,对应的拷贝对象均不会发生改变
补充:散列表(哈希表)
散列表/哈希表存储数据(比列表插入/删除数据更快)

首先对key做了哈希处理(所有数据均可)
梅森旋转算法(生成伪随机数)--》通过哈希处理对于每个key都可以生成一个序列(永不重复,且唯一)
import hashlib m = hashlib.md5() # m.update(b'a') # 0cc175b9c0f1b6a831c399e269772661 # m.update(b'b') # 92eb5ffee6ae2fec3ad71c777531578f # m.update(b'c') # 4a8a08f09d37b73795649038408b5f33 # m.update(b'd') # 8277e0910d750195b448797616e091ad m.update(b'a') # 0cc175b9c0f1b6a831c399e269772661 print(m.hexdigest())使用哈希函数对刚刚生成的序列(纯数字),除9取余


1. 为什么key是不可变数据类型
dic = {'a': 1, 'b': 2, 'c': 3, 'd': 4}
2. 为什么key不能重名dic = {'a':1, 'a':2} # key不能重名
因为会被覆盖
3. 字典为什么是乱序的
4. 散列表(哈希表)解决了什么问题
元组/字典/集合内置方法+简单哈希表(day07整理)的更多相关文章
- python之字符串,列表,字典,元组,集合内置方法总结
目录 数字类型的内置方法 整型/浮点型 字符串类型的内置方法 列表的内置方法 字典的内置方法 元组的内置方法 集合类型内置方法 布尔类型 数据类型总结 数字类型的内置方法 整型/浮点型 加 + 减 - ...
- what's the python之基本运算符及字符串、列表、元祖、集合、字典的内置方法
计算机可以进行的运算有很多种,运算按种类可分为算数运算.比较运算.逻辑运算.赋值运算.成员运算.身份运算.字符串和列表的算数运算只能用+和*,字典没有顺序,所以不能进行算数运算和比较运算.比较运算中= ...
- 元组tuple类型内置方法
目录 元组tuple类型内置方法 用途 定义 常用操作+内置方法 优先掌握 存一个值or多个值 有序or无序 可变or不可变 元组tuple类型内置方法 元组是不可变的列表,在定义完成后后面就不可以进 ...
- python之字典二 内置方法总结
Python字典包含了以下内置方法: clear()函数用于删除字典内所有元素 dict1 = {, 'Class': 'First'} print('the start len %d' % len( ...
- [Python3] 017 字典的内置方法
目录 1. Python3 中如何查看 dict() 的内置方法 2. 少废话,上例子 (1) 清理大师 clear() (2) 拷贝君 copy() (3) get(key, default=Non ...
- 7.4 元组tuple类型内置方法
元组tuple 元组相当于不可变的列表,在定义完成后后面就不可以进行更改,因此元组只可取不可存 因为不可变,所以相对列表来说,他的功能也少了很多,所以,不难理解,他有个优点就是占用内存小. 作用:能够 ...
- Python3.6 字典的内置方法
1.dict.clear(self) 删除字典内所有元素 2.dict.copy(self) 返回一个字典的浅复制,拷贝父对象,不会拷贝对象的内部的子对象 3.dict.fromkeys(self, ...
- python基础-元组(tuple)及内置方法
元组-tuple 用途:用于存储多个不同类型的值,但是不能存储可变类型数据 定义方法:用小括号存储数据,数据与数据之间通过逗号分隔,元组中的值不能改变. 注意: 1.定义元组时,如果里面只有一个值,在 ...
- python中的集合内置方法小结
#!/usr/local/bin/python3 # -*- coding:utf-8 -*- #集合性质:需要传入一个list,且不含重复的元素,无序 list_1=[1,2,1,4,5,8,3,4 ...
随机推荐
- linux添加默认网关
运维常用linux命令整理 1.临时添加 route add default gw 192.168.1.4 2.永久添加 vim /etc/sysconfig/network GATEWAY=192. ...
- ppt课件动手动脑实际验证
1关于double精度 源代码:public class Doublejingdu { public static void main(String[] args) { System.out.prin ...
- There is a cycle in the hierarchy解决
前言: 在一次项目中,分页查询公告列表信息后,在遍历查询到的公告列表时出现了死循环“There is a cycle in the hierarchy”错误,分析原因是因为在公告实体类中包含了商铺对象 ...
- ps 将图片四角变成圆角
1.用PS打开一张图片,用矩形选框工具,选出你要保留的的那一部分,“选择→修改→平滑”.在弹出的选框里添入数值,值越大角就越圆. 2.选择“选择→反选”,再按delete删除就ok了.
- S2-052 漏洞复现
Structs2框架已知的漏洞编号如下: S2-005 S2-009 S2-016 (含S2-013) S2-019 S2-020 S2-021 S2-032 S2-037(含S2-033) DevM ...
- Docker系列(一):容器监控工具Weave Scope安装
项目进行容器化之后,配套的基础设施包括监控.编排.管理等都需要进行一并完善.这里也是自己一边学习一边进行记录. Weave Scope 的最大特点是会自动生成一张 Docker 容器地图,让我们能够直 ...
- 中缀表达式转后缀表达式(Java代码实现)
后缀表达式求值 后缀表达式又叫逆波兰表达式,其求值过程可以用到栈来辅助存储.例如要求值的后缀表达式为:1 2 3 + 4 * + 5 -,则求值过程如下: 遍历表达式,遇到数字时直接入栈,栈结构如下 ...
- Win10下80端口被System占用导致Apache无法启动
Windows10下80端口被PID为4的System占用导致Apache无法启动的分析与解决方案 方法/步骤 最近更新了Windows10,总体上来说效果还是蛮不错的,然而今天在开启Apac ...
- python语言程序设计基础(嵩天)第四章课后习题部分答案
p121: *题4.1:猜数字游戏.在程序中预设一个0~9之间的整数,让用户通过键盘输入所猜的数,如果大于预设的数,显示“遗憾,太大了!”:小于预设的数,显示“遗憾,太小了!”,如此循环,直至猜中该数 ...
- Web开发小贴士 -- 全面了解Cookie
一.Cookie的出现 浏览器和服务器之间的通信少不了HTTP协议,但是因为HTTP协议是无状态的,所以服务器并不知道上一次浏览器做了什么样的操作,这样严重阻碍了交互式Web应用程序的实现. 针对上述 ...