元组/字典/集合内置方法+简单哈希表(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'] = 4
for循环
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)) # 默认给None
setdefault
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 = lt1
lt2为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 ...
随机推荐
- C语言入门-函数
一.初见函数 求出1到10.20到30和35到45的三个的和 #include <stdio.h> // 定义一个函数 void sum(int begin, int end) { int ...
- Java初中级面试笔记及对应视频讲解
笔试题链接:点击打开链接 密码:提取码:7h9e 视频下载链接: 点击打开链接 提取码:hyye 百万it课程 https://pan.baidu.com/s/1ldJ_Ak7y0VL5Xmy9 ...
- eclipse与hadoop集成,运行wordCount1
搭好了hadoop集群之后,就该使用它了 第一步:下载hadoop eclipse的插件,将它放到eclipse\plugins的目录下,然后重启eclipse,点击windows->show ...
- Spring Cloud Gateway 使用
简介 Spring Cloud Gateway是Spring Cloud官方推出的网关框架,网关作为流量入口,在微服务系统中有着十分重要的作用,常用功能包括:鉴权.路由转发.熔断.限流等. Sprin ...
- php echo/print 输出函数比较
一.两者区别 echo 支持多个字符串输出,用逗号(,)隔开,print只支持一个字符串输出 echo 输出速度比print快 echo 没有返回值,print返回值总是1 二.使用 echo e ...
- Redis的持久化机制是什么?各自的优缺点?
Redis 提供两种持久化机制 RDB 和 AOF 机制: 1.RDBRedis DataBase)持久化方式:是指用数据集快照的方式半持久化模式) 记录 redis 数据库的所有键值对,在某个时间点 ...
- ELK 学习笔记之 Kibana入门使用
Kibana入门使用: 第一次导入索引: 修改展示时间,不然查不到数据: 点Discover,查阅数据: 如果要添加新的index: 点击Visualize, 创建chart: 点击Dashboard ...
- Laravel 5 中文文档 CHM 版
使用 Microsoft HTML Help Workshop 做了一个 Laravel 5.4 中文文档的 CHM 版本. 百度网盘下载地址:http://pan.baidu.com/s/1dFN2 ...
- vue-hash-calendar,移动端日期时间选择插件
按照惯例,先上效果图 vue-hash-calendar 基于 vue 2.X 开发的日历组件 支持手势滑动操作·1 原生 js 开发,没引入第三方库 上下滑动 切换 周/月 模式 [周模式中] 左右 ...
- Java8新特性之空指针异常的克星Optional类
Java8新特性系列我们已经介绍了Stream.Lambda表达式.DateTime日期时间处理,最后以"NullPointerException" 的克星Optional类的讲解 ...