『无为则无心』Python序列 — 22、Python集合及其常用操作
1、Python集合特点
- 集合可以对自己的元素去掉重复数据。
- 集合元素的展示顺序和写入顺序不一致,所以集合元素是无序的,故集合也不支持下标。
- 集合是可变类型数据。
- 集合中只能存储不可变对象。
2、Python集合的创建
创建集合使用{}或set(), 但是如果要创建空集合只能使用set(),因为{}用来创建空字典了。
# 1.创建有数据的集合
# 可以看到集合是无序的。
# 结果:{40, 10, 50, 20, 30}
s1 = {10, 20, 30, 40, 50}
print(s1)
# 2.创建一个有重复元素的集合
# 可以看到结果,集合有去重的功能。
# 结果:{40, 10, 50, 20, 30}
s2 = {10, 30, 20, 10, 30, 40, 30, 50}
print(s2)
# 3.把一个序列作为数据,创建一个集合
# 结果去重,且无序
# 结果:{'f', 'g', 'e', 'd', 'a', 'c', 'b'}
s3 = set('abcdefga')
print(s3)
# 结果:{'猪八戒', '孙悟空', '沙和尚', '唐僧'}
name_list = ['孙悟空','猪八戒','沙和尚','唐僧']
s4 = set(name_list)
print(s4)
# 4.使用set()方法创建一个空集合
s5 = set()
print(s5) # set()
print(type(s5)) # <class 'set'>
# 5.不能使用{}创建空集合,创建出来的是一个字典。
s6 = {}
print(s6) # {}
print(type(s6)) # <class 'dict'>
# 6.集合中只能存储不可变对象。
# 结果:TypeError: unhashable type: 'list'
s = {[1,2,3],[4,6,7]}
# 存元组可以。不会报错
# 结果:{(4, 6, 7), (1, 2, 3)}
s = {(1, 2, 3), (4, 6, 7)}
print(s)
# 7.使用set()将字典转换为集合时,只会包含字典中的键
# 结果:{'c', 'a', 'b'}
s = set({'a': 1, 'b': 2, 'c': 3})
print(s)
3、操作集合常用API
(1)增加数据
@1、add()方法
只能添加不可变类型数据,序列不行。
s1 = {10, 20}
# 1.向集合中添加元素
# 结果:{10, 20, 70}
s1.add(70)
# 2.集合有去重功能,向集合中添加重复元素,不和有任何操作。
# 结果:{10, 20, 70}
s1.add(10)
print(s1)
# 3.他通过add()方法,向集合中添加序列,会报错
# 结果:TypeError: unhashable type: 'list'
print(s1)
s1.add([666, 888, 999])
因为集合有去重功能,所以,当向集合内追加的数据是当前集合已有数据的话,则不进行任何操作。
@2、update()方法
update()方法可以向集合中添加序列。
# 结果:{100, 10, 20, 200}
s1 = {10, 20}
s1.update([100, 200])
print(s1)
# 通过`update()`方法向集合添加基本类型数据,会抛异常。
# 结果:TypeError: 'int' object is not iterable
s1.update(100)
print(s1)
# update()可以传递字典作为参数,只会使用字典的键
# 结果:{100, 1000, 10, 20}
s1 = {10, 20}
s1.update({100: 'cd', 1000: 'ef'})
print(s1)
(2)删除数据
@1、remove()方法
remove()方法,删除集合中的指定数据,如果数据不存在则报错。
# 1.删除集合中指定元素
# 结果:{20, 30}
s1 = {10, 20, 30}
s1.remove(10)
print(s1)
# 2.删除的元素不存在于集合中,则会报错。
# 结果:KeyError: 40
s1.remove(40)
print(s1)
@2、discard()方法
discard()方法,删除集合中的指定数据,如果数据不存在也不会报错。
# 1.删除集合中指定元素
# 结果:{20, 30}
s1 = {10, 20, 30}
s1.discard(10)
print(s1)
# 2.删除的元素不存在于集合中,不会报错。
# 结果:{10, 20, 30}
s1.discard(40)
print(s1)
@3、pop()方法
pop()方法,随机删除集合中的某个数据,并返回这个数据。
"""
输出结果:
删除的数据为: 40
{10, 50, 20, 30}
"""
s1 = {10, 20, 30, 40, 50}
del_num = s1.pop()
print('删除的数据为:', del_num)
print(s1)
@4、claer()方法
清空集合,用法同列表、字典。
"""
输出结果:
清空前: {888, 666, 999}
清空后: set()
"""
name_set = {666, 888, 999}
print("清空前:", name_set)
name_set.clear()
print("清空后:", name_set)
(3)查找数据
你无法通过索引来查找集合中的数据。
in:判断数据在集合序列not in:判断数据不在集合序列
s1 = {10, 20, 30, 40, 50}
print(10 in s1) # True
print(10 not in s1) # False
print(100 in s1) # False
print(100 not in s1) # True
(4)copy()复制
浅复制,同字典,具体说明请点击查看字典的copy()方法。
4、集合的运算
示例如下:
# 在对集合做运算时,不会影响原来的集合,而是返回一个运算结果。
# 创建两个集合
s = {1,2,3,4,5}
s2 = {3,4,5,6,7}
# 1.& 交集运算
# 结果:{3, 4, 5}
result = s & s2
# 2.| 并集运算
# 结果:{1,2,3,4,5,6,7}
result = s | s2 #
# 3.- 差集:只在A集合里有的,B集合里没有
# 结果:{1, 2}
result = s - s2
# 4.^ 异或集 获取只在一个集合中出现的元素
# 就是两个集合中不重叠的部分。
# 结果:{1, 2, 6, 7}
result = s ^ s2
# 5.<= 检查一个集合是否是另一个集合的子集
# 如果a集合中的元素全部都在b集合中出现,
# 那么a集合就是b集合的子集,b集合是a集合超集。
a = {1,2,3}
b = {1,2,3,4,5}
result = a <= b # True
result = {1,2,3} <= {1,2,3} # True
result = {1,2,3,4,5} <= {1,2,3} # False
# 6.< 检查一个集合是否是另一个集合的真子集
# 如果超集b中含有子集a中所有元素,
# 并且b中还有a中没有的元素,则b就是a的真超集,a是b的真子集。
result = {1,2,3} < {1,2,3} # False
result = {1,2,3} <= {1,2,3} # True
result = {1,2,3} < {1,2,3,4,5} # True
# >= 检查一个集合是否是另一个的超集
# > 检查一个集合是否是另一个的真超集
print('result =',result)
『无为则无心』Python序列 — 22、Python集合及其常用操作的更多相关文章
- 『无为则无心』Python序列 — 17、Python字符串操作常用API
目录 1.字符串的查找 @1.find()方法 @2.index()方法 @3.rfind()和rindex()方法 @4.count()方法 2.字符串的修改 @1.replace()方法 @2.s ...
- 『无为则无心』Python序列 — 18、Python列表概念及常用操作API
目录 1.列表的概念 (1)列表的定义 (2)列表的应用场景 (3)列表的定义格式 2.列表的常用操作 (1)列表的查找 1)通过下标查找 2)通过方法查找 3)判断是否存在 (2)列表的增加 @1. ...
- 『无为则无心』Python序列 — 23、Python序列的公共API
目录 1.运算符 @1.+加号 @2.*乘号 @3.in或not in 2.公共方法 @1.len()方法 @2.del和del() @3.max()方法 @4.min()方法 @5.range() ...
- 『无为则无心』Python序列 — 24、Python序列的推导式
目录 1.列表推导式 (1)快速体验 (2)带if的列表推导式 (3)多个for循环实现列表推导式 2.字典推导式 (1)创建一个字典 (2)将两个列表合并为一个字典 (3)提取字典中目标数据 3.集 ...
- 『无为则无心』Python基础 — 12、Python运算符详细介绍
目录 1.表达式介绍 2.运算符 (1)运算符的分类 (2)算数运算符 (3)赋值运算符 (4)复合赋值运算符 (5)比较运算符 3.逻辑运算符 拓展1:数字之间的逻辑运算 拓展2:Python中逻辑 ...
- 『无为则无心』Python基础 — 62、Python中自定义迭代器
目录 1.迭代器对象的创建 2.实际应用案例 3.总结: 1.迭代器对象的创建 迭代器是一种可以被遍历的对象,并且能够作用于next()函数,迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问 ...
- 『无为则无心』Python基础 — 4、Python代码常用调试工具
目录 1.Python的交互模式 2.IDLE工具使用说明 3.Sublime3工具的安装与配置 (1)Sublime3的安装 (2)Sublime3的配置 4.使用Sublime编写并调试Pytho ...
- 『无为则无心』Python基础 — 6、Python的注释
目录 1.注释的作用 2.注释的分类 单行注释 多行注释 3.注释的注意事项 4.什么时候需要使用注释 5.总结 提示:完成了前面的准备工作,之后的文章开始介绍Python的基本语法了. Python ...
- 『无为则无心』Python基础 — 7、Python的变量
目录 1.变量的定义 2.Python变量说明 3.Python中定义变量 (1)定义语法 (2)标识符定义规则 (3)内置关键字 (4)标识符命名习惯 4.使用变量 1.变量的定义 程序中,数据都是 ...
- 『无为则无心』Python基础 — 10、Python字符串的格式化输出
目录 1.什么是格式化输出 2.Python格式化输出的五种方式 方式一:字符串之间用+号拼接 方式二:print()函数可同时输出多个字符串 方式三:占位符方式 方式四:f格式化方式(推荐) 方式五 ...
随机推荐
- [bug] python matplotlib 中文乱码
参考 matplotlib解决不显示中文问题 https://www.jianshu.com/p/b02ec7dc39dd
- 047.Python前端html
一 HTTP协议 1.1 HTTP请求 URL: 协议/IP:端口/路径?GET参数 基于请求响应 请求协议格式 GET URL路径?a=1&b=2 HTTP # 请求首行 user-age ...
- TCP三次握手和四次挥手及对应端口状态
一.三次握手 1.第一次握手:Client 将标志位置为1,并向Server发送个seq=j,j为随机产生的数:等待Server回复,此时Client的端口状态为SYN_SENT. 2.第二次握手:S ...
- Linux中级之负载均衡(lvs,nginx,haproxy)、中间件
一.负载均衡的概念 1.系统的扩展方式: scale up:向上扩展 scale out:向外扩展 2.集群类型: LB(Load Balancing).HA(high availability) ...
- python @staticmethod @classmethod self cls方法区别
一直在用这些东西,但是又从来没有总结过,正好今日想起来就总结一下这些东西 @staticmethod 静态方法,名义上归属类管理,不能使用类变量和实例变量,类的工具包放在函数前,不能访问类属性和实例属 ...
- 安装 error: Microsoft Visual C++ 14.0 is required 解决方案
最近写的项目需要用到Python的第三方库,比如:mmh3, pyshark等等,而直接pip install ... 会报错:error: Microsoft Visual C++ 14.0 is ...
- 巧用Reflections库实现包扫描
1.需求 需要扫描某个包中的某个接口的实现类的需求 2.maven 依赖引入 <dependency> <groupId>org.reflections</groupId ...
- 自定义pass编写
自定义pass编写 TVM是一个框架,抽象了机器学习加速器的异质性.有时,用户可能需要自定义一些分析和IR转换,使TVM适应自己的专用硬件.本文可帮助用户在TVM中编写自定义pass. 先决条件 ...
- 如何挑选深度学习 GPU?
如何挑选深度学习 GPU? 深度学习是一个对计算有着大量需求的领域,从一定程度上来说,GPU的选择将从根本上决定深度学习的体验.因此,选择购买合适的GPU是一项非常重要的决策.那么2020年,如何选择 ...
- TinyML设备设计的Arm内核
TinyML设备设计的Arm内核 Arm cores designed for TinyML devices Arm推出了两个新的IP核,旨在为终端设备.物联网设备和其低功耗.成本敏感的应用程序提供机 ...