python 集合的详细用法

news2025/1/11 22:41:23

当前版本:

  • Python 3.8.4

简介

    Python中的集合是一种无序、可哈希的且不重复的数据类型,用于存储唯一的元素。集合的实现基于哈希表,因此在插入、查找和删除元素时具有高效性能。集合的每个元素都必须是不可变的,可以是数字、字符串、元组等。

        

文章目录如下

1. 如何定义集合

集合都有哪些特点呢?

集合的定义方法

2. 集合的操作

2.1. 添加元素

2.2. 删除元素

2.3. 修改元素

2.4. 访问元素

2.5. 统计元素

2.6. 成员检查

3. 集合的运算

3.1. 并集运算

3.2. 交集运算

3.3. 差集运算

3.4. 对称差集


        

1. 如何定义集合

在python中,一般通过花括号或set来定义一个集合,例如

S = set()   # 定义一个空的集合

使用花括号定义一个有数据的集合

S = {1}

注意:由于定义集合的符号与字典一致,所以当定义一个空的花括号会被识别为字典,而不是集合

        

集合都有哪些特点呢?

  1. 集合中的元素是唯一的,重复的元素会被自动忽略。
  2. 集合是无序的,元素没有固定的位置。
  3. 集合中的元素必须是可哈希的,因此,只能包含不可变对象,如数字、字符串、元组等。
  4. 集合支持常用的集合操作,如并集、交集、差集等。

        

集合的定义方法

我们一般使用花括号来定义一个集合,当集合中存在多个数据时,使用逗号将其分割,而这些数据被称为元素。

S = {"元素1", "元素2", "元素3"}

这些元素可以是数字、字符串、元组等

S = {1.1, "AA", ("X", "Y")}

        

由于集合中的元素必须是可哈希的(hashable)。

  • 可哈希的对象是指在其生命周期内其哈希值不变的对象,例如数字、字符串、元组等。

如列表、字典是不可哈希的对象(指在其生命周期中可能发生变化的对象)是无法定义到集合中

        

虽然不能定义到集合中,但是可以将列表转换为集合

L = [1, 2, 3]
S = set(L)

由于集合其中一个特性是不可重复,这也就意味着将某个列表元素去重时,可以利用集合来实现。

# 定义一个列表
L = ["AAA", 10, "AAA", 20, "BBB"]

# 将列表转换为集合(自动去重)
S = set(L)

# 再将集合转换为列表
L = list(S)

        

2. 集合的操作

理解了集合的特性,以及定义的方式,下面介绍一些集合的常见用法:增删改查、统计、判断等。

2.1. 添加元素

常用的两种添加元素方法:

  • add:向集合中添加一个元素。如果集合中已经存在该元素,则不会进行任何操作。
  • update:向集合中添加一个或多个元素,参数可以是可迭代对象。

【案例一】添加一个元素 add

S = {"A", "B"}
S.add(10)

        

【案例二】添加多个元素 update

S = {"A", "B"}
S.update([1, 2, 3])

        

2.2. 删除元素

常见有4种删除元素的方法:

  • remove:如果元素在集合中,则移除该元素,否则会引发 KeyError 错误。
  • discard:如果元素在集合中,则移除该元素,否则不做任何操作。
  • pop:随机移除并返回集合中的一个元素。如果集合为空,会引发 KeyError 错误。
  • clear:移除集合中所有的元素

【案例一】移除一个元素,若不存在则引发错误 remove

S = {"A", "B", "C"}
S.remove("A")

        

 【案例二】移除一个元素,若不存在则不做任何操作 discard

S = {"A", "B", "C"}
S.discard("A")

        

 【案例三】随机移除一个元素,若集合为空则报错 pop

S = {"A", "B", "C"}
S.pop()

        

 【案例四】清空元素 clear

S = {"A", "B", "C"}
S.clear()

        

2.3. 修改元素

集合是无序且不可更改的,所以需要修改某个元素时只能先删除,后添加

S = {"A", "B", "C"}

# 移除B
S.discard("B")

# 添加E
S.add("E")

        

2.4. 访问元素

    由于集合是无序的,所以在需要使用索引来访问某个元素时,可以将其转换为列表后操作。但问题又来了,虽然可以使用列表访问,但顺序已经被打乱后是无法精确匹配某个元素的,这对我们来说毫无意义。

    集合一般是用于存储唯一元素的无序数据结构,重点在于元素的唯一性和高效的成员关系测试。所以它的重点并不是用于访问单个元素,而是用于快速读取。

S = {1, 2, "A", "B"}
for i in S:
    print(f"当前元素是: {i}")

        

2.5. 统计元素

这一章节主要介绍统计元素的个数、以及求最大值、最小值等

【案例一】统计元素个数 len

S = {1, 2, "A", "B"}
len(S)

        

【案例二】求最大值(仅全数字)max

S = {1.2, 5, 0.8, 6}
max(S)

        

 【案例三】求最小值(仅全数字)min

S = {1.2, 5, 0.8, 6}
min(S)

        

 【案例四】求和(仅全数字)sum

S = {1.2, 5, 0.8, 6}
sum(S)

        

 【案例五】求平均值(仅全数字)sum/len

S = {1.2, 5, 0.8, 6}
sum(S) / len(S)

        

2.6. 成员检查

  • 集合提供了一种高效的方法来检查元素是否属于某个集合。使用集合的成员关系操作,可以快速判断一个元素是否在集合中。

在集合中一般通过 in 判断某个元素是否存在。成功为True,失败为False

S = {1, 2, "A", "B"}
"A" in S
"A" not in S

        

3. 集合的运算

集合可以进行并集、交集、差集、对称差集等运算,用于解决各种集合操作问题。

3.1. 并集运算

并集是指将两个或多个集合中的所有元素合并成一个新的集合的操作。在数学符号中,通常用符号∪(并集符号)表示。在集合中使用符号 | 或者 union() 方法来实现。

  • 当两个集合中存在相同的元素时将被合并成1个。

【案例一】| 符号实现并集

S1 = {1, 2, 3}
S2 = {3, 4, 5}
union_set = S1 | S2

        

【案例二】union() 实现并集

S1 = {1, 2, 3}
S2 = {3, 4, 5}
union_set = S1.union(S2)

        

3.2. 交集运算

交集是指两个集合中共同存在的元素所构成的新集合。在数学符号中,通常用符号∩(交集符号)表示。在集合中使用符号 & 或者 intersection() 方法来实现。

【案例一】& 符号实现交集

S1 = {1, 2, 3}
S2 = {3, 4, 5}
intersection_set = S1 & S2

        

【案例二】intersection() 实现交集

S1 = {1, 2, 3}
S2 = {3, 4, 5}
intersection_set = S1.intersection(S2)

        

3.3. 差集运算

差集是指一个集合相对于另一个集合的差异部分所构成的新集合。在数学符号中,通常使用符号 (-(减号)) 或者 (-(差集符号)) 表示。在集合中使用符号 - 或者 difference() 方法来实现。

 【案例一】符号 - 实现差集

S1 = {1, 2, 3, 4, 5}
S2 = {3, 4, 5}
difference_set = S1 - S2

        

【案例二】difference() 实现差集

S1 = {1, 2, 3, 4, 5}
S2 = {3, 4, 5}
difference_set = S1.difference(S2)

        

【案例三】被 - 集合存在不同的元素

S1 = {1, 2, 3, 4, 5}
S2 = {3, 4, 5, 6}
difference_set = S1 - S2

        

3.4. 对称差集

对称差集用于表示两个集合之间的差异,包含的是那些只属于其中一个集合的元素,而不属于两个集合的交集。

【案例一】符号 ^ 实现对称差集

S1 = {1, 2, 3}
S2 = {2, 3, 4}
symmetric_difference = S1 ^ S2

        

【案例二】symmetric_difference() 实现对称差集

S1 = {1, 2, 3}
S2 = {2, 3, 4}
symmetric_difference = S1.symmetric_difference(S2)

        

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

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

相关文章

阿里AnyText:多语种图像文字嵌入的突破

模型简介 随着Midjourney、Stable Difusion等产品的兴起,文生图像技术迅速发展。然而,在图像中生成或嵌入精准文本一直是一个挑战,尤其是对中文的支持。阿里巴巴的研究人员开发了AnyText,这是一个多语言视觉文字生成与编辑模型&a…

SpringBoot 全局异常统一处理:BindException(绑定异常)

概述 在Spring Boot应用中,数据绑定是一个至关重要的环节,它负责将HTTP请求中的参数映射到控制器方法的入参对象上。在这个过程中如果遇到任何问题,如参数缺失、类型不匹配或验证失败等,Spring MVC将会抛出一个org.springframewo…

安达发|APS工序排程甘特图功能介绍

工序排程甘特图的主要功能 1. 显示工序时间安排:工序排程甘特图可以清晰地展示生产过程中各个工序的开始时间、结束时间和持续时间,从而帮助企业了解生产过程中各个环节的时间安排。 2. 显示工序进度情况:通过工序排程甘特图,企业…

通过myBatis将sql语句返回的值自动包装成一个java对象(3)

1.如果sql字段和java字段名字不一样怎么办? 之前我们将sql返回值转换为java对象时,每条sql的返回值的字段名和java类中的字段名是一一对应的,ie:sql选择的user有username和password两个字段,java中的user对象也有两个…

开源项目CuteSqlite开发笔记(七):CuteSqlite释放BETA版本啦

经过大半年的开发,CuteSqlite程序代码不知不觉来到了6万行,有效行数4万行,CuteSqlite开发完成了一个小版本,进入下一个阶段,并于2024元旦释放BETA版本,有兴趣的朋友可以下载试用。 GitHub下载https://gith…

Linux系统下编译MPlayer

一、编译MPlayer 在 http://www.mplayerhq.hu/design7/dload.html 下载MPlayer源码 执行命令: tar -xf MPlayer-1.5.tar.xz cd MPlayer-1.5 ./configure --prefix$(pwd)/install --yasm make make install 然后在install/bin目录下即会生成mplayer的可执行文件 二…

基于Java+SSM的技术的社区人口管理系统详细设计和实现【附源码】

基于JavaSSM的技术的社区人口管理系统详细设计和实现 🍅 作者主页 央顺技术团队 🍅 欢迎点赞 👍 收藏 ⭐留言 📝 🍅 文末获取源码联系方式 📝 🍅 查看下方微信号获取联系方式 承接各种定制系统 …

elasticsearch[一]-索引库操作(轻松创建)、文档增删改查、批量写入(效率倍增)

elasticsearch[一]-索引库操作(轻松创建)、文档增删改查、批量写入(效率倍增) 1、初始化 RestClient 在 elasticsearch 提供的 API 中,与 elasticsearch 一切交互都封装在一个名为 RestHighLevelClient 的类中,必须先完成这个对象的初始化,…

Vue知识总结-下

VUE-组件间通信 组件的自定义事件 概述:是一种组件间通信的方式,适用于:子组件>父组件使用场景:A是父组件,B是子组件,B给A传递数据,那么需要在A组件中绑定自定义事件(事件的回调也在A中)使用步骤 绑定自定义事件: 第一种方式…

2024年AMC8历年真题练一练和答案详解(9),以及全真模拟题

“熟读唐诗三百首,不会作诗也会吟”,反复做真题、吃透真题、查漏补缺并举一反三是在各类考试、比赛中得高分的重要学习方法之一,参加AMC8竞赛也是如此。 六分成长继续为您分享AMC8历年真题,最后几天,通过高质量的真题来体会快速思…

dp--62. 不同路径/medium 理解度A

62. 不同路径 1、题目2、题目分析3、复杂度最优解代码示例4、抽象与扩展 1、题目 给定一个包含非负整数的 m x n 网格 grid ,请找出一条从左上角到右下角的路径,使得路径上的数字总和为最小。 说明:每次只能向下或者向右移动一步。 示例 1&…

Rust-NLL(Non-Lexical-Lifetime)

Rust防范“内存不安全”代码的原则极其清晰明了。 如果你对同一块内存存在多个引用,就不要试图对这块内存做修改;如果你需要对一块内存做修改,就不要同时保留多个引用。 只要保证了这个原则,我们就可以保证内存安全。 它在实践…

IOC之Spring统一资源加载策略

前言 在学 Java的时候,我们学习了一个标准类 java.net.URL,该类在 Java SE 中的定位为统一资源定位器(Uniform Resource Locator),但是我们知道它的实现基本只限于网络形式发布的资源的查找和定位。然而,实…

Linux环境搭建FastDFS文件服务器(附带Nginx安装)

本文主要介绍在linux服务器如何搭建FastDFS文件服务器。大概分为9个步骤,由于内容较为繁琐。下面带你入坑! 首先简单介绍一下FastDFS是淘宝资深架构师余庆老师主导开源的一个分布式文件系统,用C语言编写。适应与中小企业,对文件不…

【教3妹学编程-算法题】3008. 找出数组中的美丽下标 II

3妹:呜呜,烦死了, 脸上长了一个痘 2哥 : 不要在意这些细节嘛,不用管它,过两天自然不就好了。 3妹:切,你不懂,影响这两天的心情哇。 2哥 : 我看你是不急着找工作了啊, 工作…

Python - 深夜数据结构与算法之 LRUCache

目录 一.引言 二.LRU Cache 简介 1.实现特性 2.工作流程 三.LRU Cache 实战 1.HashMap ListNode 2.OrderedDict 四.总结 一.引言 LRU 即 Least Recently Used 意为最近使用,它是一种局部 Cache 的缓存方法,用于存储最近使用的元素,…

2023.1.15 关于 Redis 持久化 RDB 策略详解

目录 Redis 持久化 Redis 实现持久化的两大策略 RDB 策略 手动触发 save 命令 bgsave 命令 bgsave 命令执行流程 自动触发 rdb 文件 实例演示一 实例演示二 实例演示三 实例演示四 RDB 策略的优缺点 Redis 持久化 什么是持久化? 回答: 将数据存…

高效视频剪辑:视频合并让视频焕然一新,添加背景音乐更动听

随着社交媒体和数字内容的普及,视频剪辑已成为一项常用的技能。除了基本的剪辑技巧外,添加合适的背景音乐也是提升视频质量的方法。下面来看云炫AI智剪的高效视频剪辑技巧——如何批量合并视频,添加动听的背景音乐。 视频合并后的效果展示&a…

Jenkins之pipeline

安装插件 Pipeline Pipeline: Stage View Plugin 创建任务 配置 demo 开始实践 拉取git仓库代码 checkout scmGit(branches: [[name: */main]], extensions: [], userRemoteConfigs: [[url: http://178.119.30.133:8929/root/mytest.git]])通过SonarQube做质量检测 sh …

MAC iterm 显示git分支名

要在Mac上的iTerm中显示Git分支名,您需要使用一个名为“Oh My Zsh”的插件。Oh My Zsh是一个流行的Zsh框架,它提供了许多有用的功能和插件,包括在终端中显示Git分支名。 以下是在iTerm中显示Git分支名的步骤: 1、安装Oh My Zsh&…