元组/字典/集合内置方法+简单哈希表(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 ...
随机推荐
- MySQL之增删改查之
MySQL之增删改查 前言:以下是MySQL最基本的增删改查语句,很多IT工作者都必须要会的命令,也是IT行业面试最常考的知识点,由于是入门级基础命令,所有所有操作都建立在单表上,未涉及多表操作. ...
- Regex分组与Pattern正则表达式对象
1.正则规则: 1.String regex = "[1-9]" 表示单个字符的取值范围是 1~9,注意是单个字符的取值范围 2 ...
- js数组的增删改查
array 数组的增删改: push 从数组后面推入一个元素或多个元素 var arr = [1,2,3]; // 返回:修改后数组的长度 arr.push(4,5,6); pop 删除数组最后一 ...
- IntelliJ IDEA 如何在同一个窗口创建多个项目--超详细教程
一.IntelliJ IDEA与Eclipse的区别 二.在同一个窗口创建多个项目 1.打开IntelliJ IDEA,点击Create New Project 2.Java Enterprise-- ...
- python2和3区别
核心类差异 Python3对Unicode字符的原生支持 Python2中使用 ASCII 码作为默认编码方式导致string有两种类型str和unicode,Python3只支持unicode的st ...
- Spring Security 前后端分离登录,非法请求直接返回 JSON
hello 各位小伙伴,国庆节终于过完啦,松哥也回来啦,今天开始咱们继续发干货! 关于 Spring Security,松哥之前发过多篇文章和大家聊聊这个安全框架的使用: 手把手带你入门 Spring ...
- IDEA 学习笔记之 Console显示日志大小
Console显示日志大小: IntelliJ IDEA默认的Output输出缓存区大小只有1024KB,超过大小限制的就会被清除,而且还会显示[too much output to process] ...
- Drill 学习笔记之 入门体验
简介: Apache Drill是一个低延迟的分布式海量数据(涵盖结构化.半结构化以及嵌套数据)交互式查询引擎.分布式.无模式(schema-free) 是Google Dremel的开源实现,本质是 ...
- MongoDB 学习笔记之 手动预先分片
手动预先分片: 目的:手动预先分片是为了防止未来chunk的移动,减少IO. sh.shardCollection("shop.users",{"userId" ...
- mysql引号与esc键下方键
navicat导出数据表发现建表语句如下: create table `product_category` ( `category_id` int not null auto_increment, ` ...