Python学习之集合set
作者:小瑀1987 发布时间:2021-07-25 10:44:34
集合 (set)
1、由不同的元素组成,用{ }大括号括起来,用,逗号隔开
2、无序的
3、集合中的元素必须是比可变类型
4、集合会自动去重
例如:s = {1,2,3,4,5,6} #这就是一个集合
5、合集是可变的 但是可以通过参数frozenset变成不可变的集合
s = {1,'2',3,4,5,6}
print(s) #{'2', 1, 3, 4, 5, 6}
a = frozenset(s) #不可变
print(a) #frozenset({'2', 1, 3, 4, 5, 6})
一 、合集的一些常用命令
1、set 定义合集
s = set('adam')
print(s) #{'m', 'a', 'd'}
可以看到输出结果是 乱序的 而且 已经去重了,并且它已经把原来的字符串 打散到了最小单位
2、add 添加元素
s = {1,2,3,4,5,6}
s.add('3') #添加了一个str类型的 3
print(s) #{1, 2, 3, 4, 5, 6, '3'}
s.add(('4', 'a', 'b', 'c'))
print(s) #{1, 2, 3, 4, 5, 6, ('4', 'a', 'b', 'c'), '3'}
1、如果添加的是的集合里面原本就含有的元素,那么就会被自动去重
2、被添加的元素是 被乱序放入的 也就是说集合本身是乱序的
3、如果被添加的是 多个元素 那么 集合会把他们视为一个元素 打包插入,只有元祖可以插入,列表和字典不行
3、clear 清空
s = {1,2,3,4,5,6}
s.clear()
print(s) #set()
4、pop 随机删除一个元素
s = {1,2,3,4,5,6,7}
s.pop()
print(s) #{2, 3, 4, 5, 6, 7}
5、remove 指定删除
s = {1,2,3,4,5,6}
s.remove(3)
print(s) #{1, 2, 4, 5, 6}
PS:找不到匹配要删除的字符就会报错
6、discard 指定删除
s = {1,2,3,4,5,6}
s.discard(7)
print(s) #{1, 2, 3, 4, 5, 6}
PS:找不到匹配要删除的字符不会报错
二、关系运算
1、交集 找到两个集合相同的元素
s = {1,2,3,'m', 'a', 'd'}
s1 ={1,'2',3,'m', 'd'}
print(s&s1) #{1, 3, 'd', 'm'}
print(s.intersection(s1)) #{1, 3, 'd', 'm'}
& 是运算符号, intersection 是运算命令他们的结果是一样的
2、并集 合并两个集合
s = {1,2,3,'m', 'a', 'd'}
s1 ={1,'2',3,'m', 'd'}
print(s|s1) #{1, 2, 3, 'm', '2', 'd', 'a'}
print(s.union(s1)) #{1, 2, 3, 'm', '2', 'd', 'a'}
| 竖是运算符号,union 是运算命令他们的结果是一样的
3、差集 保留前者与后者不同的元素 去除相同的元素
s = {1,2,3,'m', 'a', 'd'}
s1 ={1,'2',3,'m', 'd'}
print(s - s1) #{'a', 2}
print(s1.difference(s)) #{'2'}
- 减号是运算符号,difference 是运算命令他们的结果是一样的
由于前后两次 两个 集合被比较的 关系对调了 所以 结果两次输出的结果也不同
4、交叉补集 只保留两者不同的部分
s = {1,2,3,'m', 'a', 'd'}
s1 ={1,'2',3,'m', 'd'}
print(s ^ s1) #{2, '2', 'a'}
print(s1.symmetric_difference(s)) #{2, '2', 'a'}
^ 是运算符号,symmetric_difference是运算命令他们的结果是一样的
5、isdisjoint 判断是否有交集返回布尔值
s = {1,2,3,'m', 'a', 'd'}
s1 ={1,'2',3,'m', 'd'}
s2 = {15,22}
print(s1.isdisjoint(s2)) #True
print(s1.isdisjoint(s)) #False
没有交集就返回 True 有交集就返回False
6、issubset判断后者是否包含前者 返回布尔值
s = {1,2,3,'m', 'a', 'd'}
s1 ={1,2,3,'m', 'd'}
s2 = {15,22,1}
print(s1.issubset(s2)) #False
print(s1.issubset(s)) #True
如果后者包含前者 则返回 True 如果后者不完全包含前者 则返回 False
7、issuperset判断前者是不是完全包含后者,返回布尔值
s = {1,2,3,'m', 'a', 'd'}
s1 ={1,2,3,'m', 'd'}
s2 = {15,22,1}
s3 ={1,2,3,'m', 'a', 'd'}
print(s.issuperset(s2)) #False
print(s.issuperset(s1)) #True
print(s.issuperset(s3)) #True
前者完全包含后者 则 返回 True 没有完全包含后者则返回False 前后两者相等也是True
8、update 更新
s = {1,2,3,'m', 'a', 'd'}
s3 ={1,2,3,'m', 'a', 'd'}
s1 ={1,2,3,'m', 'd'}
s2 = {15,22,1}
s.update(s3)
print(s) #{1, 2, 3, 'a', 'm', 'd'}
print(s3) #{1, 2, 3, 'd', 'm', 'a'}
s1.update(s2)
print(s1) #{1, 2, 3, 'm', 22, 'd', 15}
print(s2) #{1, 22, 15}
把后者的元素 更新到前者内
PS:
访问方式
直接 访问:数字
顺序访问:字符串、列表、元祖
映射(keys):字典
字典的查询速度最快 但是字典占内存会比较高
存放元素个数:
容器类(存放多个值):列表、元祖、字典
原子类(只能存放一个值):数字、字符串
来源:https://blog.csdn.net/weixin_56164201/article/details/121016046


猜你喜欢
- 原文作者:青女 附注及色样添加:Quester西式的色名及色样表,可以参见以下链接 (Java 类色彩兼容):http
- 关于jQuery的链式调用真正有意义的链式调用也就是方法链(method chaining)。方法链这个词是有的,而且使用的很广泛。其实很多
- 本文实例讲述了Python排序搜索基本算法之冒泡排序。分享给大家供大家参考,具体如下:冒泡排序和选择排序类似,也是第n次把最小的元素排在第n
- Create trigger tri_wk_CSVHead_History on wk_CSVHead_History --声明一个tri_
- DATEPART() 函数用于返回日期/时间的单独部分,比如年、月、日、小时、分钟等等。DATEDIFF() 函数返回两个日期之间的时间差。
- 一、问题描述一段 Python 代码在本地的 IDE 上运行正常,部署到服务器运行后,出现了 ModuleNotFoundError: No
- 废话不多说, 先看代码创建一个钉钉机器人, 必须使用加签方式1. 安装 ding 模块包go get -u github.com
- 数据库在时回加for xml auto调用方法 SqlCommand SqlComm=
- 在使用python做数据分析的时候,经常需要先对数据做统一化的处理,缺失值的处理是经常会使用到的。一般情况下,缺失值的处理要么是删除缺失数据
- 概要在前面章节我们为主页定义了一个简单的模板,部分尚未实现的模块如用户或帖子等使用模拟的对象作为临时占位。本章我们将看到如何利用
- forms组件django框架提供了一个Form类,来进行web开发中的表单提交数据的处理工作。导入相关模块from django impo
- Deferred对象结构Deferred由一系列成对的回调链组成,每一对都包含一个用于处理成功的回调(callbacks)和一个用于处理错误
- 目录一.准备数据创建数据表插入数据二.SQL演练1. SQL语句的强化2. 创建 "商品分类"" 表3. 同步
- 网络开发的在分页上要是遇到数(几十)万以上的数据还是用ADO那样的分页会速度很慢的。有了存储过程速度就快多了。下面是本人用50万的数据进行的
- 实验环境:tensorflow版本1.2.0,python2.7介绍关于空洞卷积的理论可以查看以下链接,这里我们不详细讲理论:1.Long
- 在计算机普及的现代设计领域,文字的设计的工作很大一部分由计算机代替人脑完成了(很多平面设计软件中都有制作艺术汉字的引导,以及提供了数十上百种
- 作者|Nicholas Ballard编译|VK来源|Towards Data Science可以说,每一个“使用计算机的人”都需要在某个时
- 在Mysql中很多表都包含可为NULL(空值)的列,即使应用程序并不需要保存NULL也是如此,这是因为可为NULL是列的默认属性。但我们常在
- onactivate
- PHP mysqli_sqlstate() 函数返回最后一个 MySQL 操作的 SQLSTATE 错误代码:<?php// 假定数据