Python数据结构集合的相关介绍

news2025/1/4 19:24:51

集合是一种无序、可变的数据结构,它也是一种变量类型,集合用于存储唯一的元素。集合中的元素不能重复,并且没有固定的顺序。在Python 提供了内置的 set 类型来表示集合,所以关键字set就是集合的意思。

你可以使用大括号 {} 或者 set() 函数来创建一个集合。

my_set = {1, 2, 3}  # 使用大括号创建集合
print(my_set)  # 输出: {1, 2, 3}

my_set = set([1, 2, 3]) # 使用 set() 函数创建集合
print(my_set)  # 输出: {1,2, 3}

需要注意的是,集合是无序的,没有固定的顺序。因此,集合元素的顺序可能与你创建或添加的顺序不同。

集合具有以下特点:

  • 集合中的元素是唯一的,不重复。如果重复相同的元素,集合将自动去重。
  • 集合是无序的,没有固定的顺序。因此,你无法像列表或元组那样索引来访问集合中的元素。
  • 集合是可迭代的,你可以使用 for 循环遍历集合中的元素。
  • 集合是可变的,你可以添加、删除和修改集合中的元素

创建集合

要使用集合,首先就必须要创建,那么在 Python 中,有哪些创建集合的方式呢?你可以使用以下几种方式创建集合。

1、 使用大括号 {} 或者 set() 函数创建一个集合,将元素用逗号隔开:

my_set = {1, 2, 3}  # 使用大括号创建集合
print(my_set)  # 输出: {1, 2, 3}

my_set = set([1, 2, 3]) # 使用 set() 函数创建集合
print(my_set)  # 输出: {1, 2, 3}

注意,如果你使用空的大括号 {} 来创建一个对象,那么创建的将是一个空字典,而非空集合。因此,你必须使用 set() 函数来创建一个空集合:

empty_set = set()
print(empty_set)  # 输出: set()

2、 使用集合推导式来创建集合。集合推导式的语法类似于列表推导式,只需将中括号 [ ] 替换为大括号 { }

my_set = {i for i in range(1, 5)}
print(my_set)  # 输出: {1, 2, 3, 4}

3、 将其他可迭代的对象(列表、字符串、元组等)转换为集合,可以使用 set() 函数来实现:

my_list = [1, 2, 3, 2]
my_set = set(my_list)
print(my_set)  # 输出: {1, 2, 3}

my_string = 'hello'
my_set ={my_string}
print(my_set)  # 输出: {'h', 'e', 'l', 'o'}

访问集合

由于集合是无序的,没有固定的索引,使用索引访问集合中的元素是不可行的,要访问集合中的元素,你可以使用迭代器或者通过成员运算符来实现。

1、 使用迭代器:通过使用 for 循环遍历集合中的每个元素。

my_set = {1, 2, 3}
for item in my_set:
    print(item)

2、 使用成员运算:使用 in 或者 not in 运算符来检查元素是否存在于集合中。

my_set = {1, 2, 3}
print(2 in my_set)  # 输出: True
print(4 not in my_set)  # 输出: True

删除集合

在 Python 中,可以使用 del 关键字来删除集合:

1、 使用 del 关键字删除集合变量,删除之后如果再次访问,就会发生错误。

my_set = {1, 2, 3}
del my_set

修改集合元素

创建的集合,我们可以对其中的集合元素进行操作,不仅可以添加元素,还是可以删除其中的元素。

添加集合元素

1、使用 add() 方法向集合中添加元素。

my_set = {1, 2, 3}
my_set.add(4)
print(my_set)  # 输出: {1, 2, 3, 4}

2、使用列表的解包操作添加多个元素。

my_set = {1, 2, 3}
new_elements = [4, 5]
my_set.update(new_elements)
print(my_set)  # 输出: {1, 2, 3, 4, 5}

因为集合的元素是唯一的,所以如果添加了重复的元素,那么重复的元素不会被添加到集合中,当然执行的过程并不会发生报错,只是不会被添加进去而已。在使用update()方法时,传入的参数可以是一个集合、列表或者其他可迭代对象。

删除集合元素

1、 使用 remove() 方法删除指定元素:remove() 方法会从集合中删除指定的元素。如果集合中不存在该元素,会引发 KeyError 异常。

my_set = {1, 2, 3, 4}
my_set.remove(3)
print(my_set)  # 输出: {1, 2,4}

my_set.remove(5)  # 删除不存在的元素,引发 KeyError 异常

2、 使用 discard() 方法删除指定元素:discard() 方法会从集合中删除指定的元素。如果集合不存在该元素,该不会引发异常而是不进行任何操作。

my_set = {1, 2, 3 4}
my_set.discard(3)
(my_set)  # 输出: {1, 2, 4}

my_set.discard(5)  # 删除不存在的元素,不会引发异常

3、 clear() 方法清空集合:clear() 方法会清空集合元素。

my_set = {1, 2, 3, 4}
my_set.clear()
print(my_set)  # 输出: set()

集合运算:

集合的运算指的是对集合进行一系列操作,包括求并集、交集、差集和对称差集等。这些运算可通过运算符或方法来进行。

并集(Union)

可以使用 | 运算符或者 union() 方法来获取两个集合的并集。所谓的并集就是包含set1和set2集合的所有元素。

set1 = {1, 2, 3}
set2 = {3, 4, 5}
set3 = set1 | set2  # 使用 | 运算符
# 或者使用 union() 方法
# set3 = set1.union(set2)
print(set3)  # 输出: {1, 2, 3, 4, 5}

交集(Intersection)

可以使用 & 运算符或者 intersection() 方法来获取两个集合的交集。所谓的交集就是取set1和set2集合的相同元素,没有相同元素的话返回的就是set()

set1 = {1, 2, 3}
set2 = {3, 4, 5}
set3 = set1 & set2  # 使用 & 运算符
# 或者使用 intersection() 方法
# set3 = set1.intersection(set2)
print(set3)  # 输出: {3}

差集(Difference)

可以使用 - 运算符或者 difference() 方法来获取两个集合的差集。所谓的差集就是set1中独有的元素,如果set1中的元素,在set2中也有,那么就该元素就不能在差集中。如果是set2 - set1,那就是set2中独有的元素。结果为空的返回就是set()

set1 = {1, 2, 3}
set2 = {3, 4, 5}
set3 = set1 - set2  # 使用 - 运算符
# 或者使用 difference() 方法
# set3 = set1.difference(set2)
print(set3)  # 输出: {1, 2}

对称差集(Symmetric Difference)

可以使用 ^ 运算符或者 symmetric_difference() 方法来获取两个集合的对称差集。所谓的对称差集就是set1和set2中相同的元素剔除,剩下的元素就是对称差集。

set1 = {1, 2, 3}
set2 = {3, 4, 5}
set3 = set1 ^ set2  #使用 ^ 运算符
# 或者使用 symmetric_difference() 方法
# set3 = set1.symmetric_difference(set2)
print(set3)  # 输出: {1, 2, 4, 5}

需要注意的是,在使用集合运算符时,两个集合的元素类型必须一致。另外,集合的元素是唯一的,不会出现重复。

除了运算符外,还有其他一些常用的集合方法,比如 intersection_update() 方法用于在原集合上更新为两个集合的交集,difference_update() 方法用于在原集合上更新为两个集合的差集,symmetric_difference_update() 方法用于在原集合上更新为两个集合的对称差集。

集合的相关函数

Python中的集合也有不少相关的方法,以下就是列举了集合中常用的方法,如有错误的地方欢迎指出。

函数名解释
add(element)向集合中添加一个元素。
clear()移除集合中的所有元素。
copy()返回集合的副本。
difference(other_set[, ...])返回该集合与其他集合的差集。
difference_update(other_set[, ...])移除该集合中与其他集合相同的元素,并更新原集合。
discard(element)移除集合中指定的元素。
intersection(other_set[, ...])返回该集合与其他集合的交集。
intersection_update(other_set[, ...])移除该集合中与其他集合不同的元素,并更新原集合。
isdisjoint(other_set)如果两个集合没有共同的元素,则返回 True;否则返回 False。
issubset(other_set)如果该集合是另一个集合的子集,则返回 True;否则返回 False。
issuperset(other_set)如果该集合是另一个集合的超集,则返回 True;否则返回 False。
pop()随机移除并返回集合中的一个元素。
remove(element)移除集合中指定的元素。若元素不存在,将引发 KeyError 错误。
symmetric_difference(other_set)返回该集合与其他集合的对称差集。
symmetric_difference_update(other_set)移除该集合中与其他集合相同的元素,并更新原集合。
union(other_set[, ...])返回该集合与其他集合的并集。
update(other_set[, ...])向集合中添加其他集合的元素,并更新原集合。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2123933.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

pytest 生成allure测试报告

allure的安装 github地址 allure资产列表 windows下载.zip,解压并配置环境变量PATH;linux下载tar.gz,解压配置; allure作为pytest插件 # 安装 pip install allure-pytest# 执行单元测试,生成allure测试数据&…

如何在内网中与阿里云服务器进行文件传输?[2024详细版]

随着云计算发展,企业和个人选择将数据存储在云端,以提高数据的安全性和可访问性。阿里云作为国内领先的云服务提供商之一,提供了多种云产品和服务。其中,云服务器ECS(Elastic Compute Service)因其灵活性和…

网络初识-相关概念

本篇主要介绍关于网络的相关概念~ 相关概念 局域网: 把几个电脑连接到一起,或者几台电脑连接到同一个路由器,就能构成局域网,局域网中的电脑可以相互通信。 广域网: 将多个局域网连接起来,就构成了范围更…

以一种访问权限不允许的方式做了一个访问套接字的尝试

System.Net.Sockets.SocketException: 以一种访问权限不允许的方式做了一个访问套接字的尝试. 近来做的一个net core的网页,突然有这样的一个提示。上网查询之后,有二种可能,1,管理员角色运行VS2022后重新编译一下项目。2&#x…

9.10javaweb项目总结

1.创建吧 这里的话,是用的那个模态背景来写的,就是可以在原有界面上进行创建。目前就只有这些内容,具体一点就是吧吧的分类弄了一下,然后还有待完善,就是贴吧,吧头像的设置,还是有点问题的&…

AutoSar AP平台的SOMEIP文档的理解笔记

1. SOMEIP报文格式 1.1 SOME/IP消息格式:头格式 1.2 SOME/IP头格式:Request ID (Client ID/Session ID) 1.3 SOME/IP头格式:Message Type [8 Bit] and Return Code [8 Bit] 1.4 SOME/IP消息格式的大小端 1.5 SOME/IP消息格式:序列…

揭秘开发者的效率倍增器:编程工具的选择与应用

文章目录 每日一句正能量前言工具介绍功能特点:使用场景:提高工作效率的方式: 效率对比未来趋势后记 每日一句正能量 这推开心窗之人,可以是亲朋好友,也可以是陌客路人,可以是德高望重的哲人名流&#xff0…

Nexpose v6.6.266 for Linux Windows - 漏洞扫描

Nexpose v6.6.266 for Linux & Windows - 漏洞扫描 Rapid7 Vulnerability Management, release Aug 21, 2024 请访问原文链接:https://sysin.org/blog/nexpose-6/,查看最新版。原创作品,转载请保留出处。 作者主页:sysin.o…

JavaScript --while案例求一个数字的阶乘

求5*4*3*2*1的值 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible" content"IEedge"><meta name"viewport" content"widthdevice-w…

Probabilistic Embeddings for Cross-Modal Retrieval 论文阅读

Probabilistic Embeddings for Cross-Modal Retrieval 论文阅读 Abstract1. Introduction2. Related work3. Method3.1. Building blocks for PCME3.1.1 Joint visual-textual embeddings3.1.2 Probabilistic embeddings for a single modality 3.2. Probabilistic cross-modal…

摩托车加装车载手机充电usb方案/雅马哈USB充电方案开发

长途骑行需要给手机与行车记录仪等设备供电&#xff0c;那么&#xff0c;加装USB充电器就相继在两轮电动车上应用起来了。摩托车加装usb充电方案主要应用于汽车、电动自行车、摩托车、房车、渡轮、游艇等交通工具。提供电动车USB充电器方案/摩托车加装usb充电方案/渡轮加装usb充…

深入理解Java虚拟机:Jvm总结-垃圾收集器与内存分配策略

第三章 垃圾收集器与内存分配策略 3.1 意义 Java堆和方法区具有不确定性&#xff1a;一个接口的多个实现类、一个方法的不同条件分支需要的内存可能不一样。程序运行起来才知道到底会创建什么对象&#xff0c;创建多少个对象。动态分配内存和垃圾回收排查内存泄漏和内存溢出时…

FLBOOK一款强大的样本册制作工具

​在数字化时代&#xff0c;样本册的制作与展示已成为企业宣传和业务拓展的重要手段。一款强大的样本册制作工具&#xff0c;不仅能帮助企业高效地打造精美的样本册&#xff0c;还能提升企业的专业形象和市场竞争力。今天&#xff0c;我要向大家介绍一款名为FLBOOK的样本册制作…

【银河麒麟高级服务器操作系统】虚拟机服务器执行systemctl提示timeout——分析全过程及处理建议

了解更多银河麒麟操作系统全新产品&#xff0c;请点击访问 麒麟软件产品专区&#xff1a;https://product.kylinos.cn 开发者专区&#xff1a;https://developer.kylinos.cn 文档中心&#xff1a;https://documentkylinos.cn 现象描述 产品信息 产品名称 银河麒麟高级服务…

【Python报错已解决】 raise JSONDecodeError(“Expecting value“, s, err.value) from None

&#x1f3ac; 鸽芷咕&#xff1a;个人主页 &#x1f525; 个人专栏: 《C干货基地》《粉丝福利》 ⛺️生活的理想&#xff0c;就是为了理想的生活! 文章目录 前言一、问题描述1.1 报错示例1.2 报错分析1.3 解决思路 二、解决方法2.1 方法一&#xff1a;确保JSON字符串完整2.2 …

vue 使用vue-quill-editor 富文本添加源码模式,查看源码功能和表格功能

今天接到个需求&#xff0c;在富文本中增加查看源码和增加表格功能&#xff0c;感觉这种功能手拿把掐&#xff0c;但是奈于平时沉迷于移动端有段时间没写pc了&#xff0c;看了下官方感觉一个头两个大&#xff0c;于是在茫茫文档中各种借鉴&#xff08;抄袭&#xff09;完成了功…

练习:基于TCP协议实现一个网盘系统

一. 题目介绍 请基于TCP协议实现一个网盘系统&#xff0c;包含客户端、服务端&#xff0c;各自需求如下&#xff1a; - 客户端 - 用户注册&#xff0c;注册成功之后&#xff0c;在服务端的指定目录下为此用户创建一个文件夹&#xff0c;该文件夹下以后存储当前用户的数据&…

【python因果推断库15】使用 sci-kit learn 模型进行回归断点分析

目录 导入数据 线性模型和主效应模型 线性模型、主效应模型和交互作用模型 使用bandwidth from sklearn.gaussian_process import GaussianProcessRegressor from sklearn.gaussian_process.kernels import ExpSineSquared, WhiteKernel from sklearn.linear_model import …

存储课程学习笔记5_iouring的练习(io_uring,rust_echo_bench,fio)

我们知道&#xff0c;在处理大量高并发网络时&#xff0c;一般考虑并发&#xff0c;以及设计对应的方案&#xff08;比如select,poll,epoll&#xff09;等。 那么如果频繁进行文件或者磁盘的操作&#xff0c;如何考虑性能和并发&#xff0c;这里就可以考虑用到io_uring。 0&a…

C语言深入理解指针二(15)

文章目录 前言一、指针变量类型的意义指针的解引用指针-整数void*指针 二、const修饰指针const修饰变量 三、指针运算指针-整数指针-指针指针比较大小 四、野指针野指针成因如何规避野指针 总结 前言 本节课开始上点有意思的内容了&#xff01; 一、指针变量类型的意义 指针的…