元组/字典/集合内置方法+简单哈希表(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 ...
随机推荐
- java 数组定义
1.方式一: 数组声明: int[] intArr ; String [] strArr; int [][] intArrs; 数组初始化: intArr = new int[6]; //一维数组 s ...
- ELK搭建实时日志分析平台
ELK搭建实时日志分析平台 导言 ELK由ElasticSearch.Logstash和Kiabana三个开源工具组成,ELK平台可以同时实现日志收集.日志搜索和日志分析的功能.对于生产环境中海量日志 ...
- Maven 梳理-安装配置
项目构建过程包括[清理项目]→[编译项目]→[测试项目]→[生成测试报告]→[打包项目]→[部署项目]这几个步骤,这六个步骤就是一个项目的完整构建过程. 下载后解压 配置环境变量 F:\jtDev ...
- 阿里云服务器CentOS6.9安装Tomcat
上篇讲了CentOS6.9安装jdk,这篇来讲Tomcat的安装,本来准备使用yum命令安装的,但是通过 yum search tomcat 发现只有tomcat6,所以就在官网下了一个tomcat8 ...
- freemarker常见语法
FreeMarker的插值有如下两种类型:1,通用插值${expr};2,数字格式化插值:#{expr}或#{expr;format} ${basketball.name?if_exists } / ...
- 使用 Chrome 对长网页(知乎、微信公众号文章)进行完整截图
当需要对一个较长的网页进行完整截图时,可以直接使用谷歌浏览器(Chrome)自带的截图功能完成,不需要依赖第三方截图软件. 1. 打开网页 以微信公众号的页面作为示例:https://mp.weixi ...
- 一致性hash (PHP)
<?php /** * Flexihash - A simple consistent hashing implementation for PHP. * * The MIT License * ...
- .Net下MoongoDB的简单调用
1.安装.Net 驱动:Install-Package MongoDB.Driver 2.数据插入 //新建Person测试类 public class Person { public long Id ...
- Win10实现多用户同时进行远程桌面连接的解决方案
Win10无法实现多用户远程桌面连接的解决方案以下方法解决Win10无法同时多用户登录.推荐:win10正式版下载 以下为必要步骤需先进行组策略设置,完成后再选择方法1或2(推荐方法2): 远程桌面连 ...
- Unreal Engine 4 系列教程 Part 2:蓝图教程
.katex { display: block; text-align: center; white-space: nowrap; } .katex-display > .katex > ...