首页 > 编程语言 >Python 集合:深入理解与应用

Python 集合:深入理解与应用

时间:2024-07-15 14:01:36浏览次数:28  
标签:Python s2 s1 元素 print 深入 集合 difference

一、引言

1.在 Python 编程中,集合(Set)是一种强大而有用的数据结构。它具有独特的特性,适用于解决各种问题,特别是在处理不重复元素和集合操作时。

二、集合的创建

# 使用花括号创建集合
set1 = {1, 2, 3, 4, 5}

# 使用 set() 函数创建集合
set2 = set([5, 6, 7, 8, 9])

三、集合的特性

1.无序性
集合中的元素是无序存储的,这意味着您不能依赖特定的顺序来访问或操作元素。

set1 = {1, 2, 3}
print(set1)  

代码执行结果如下:

2.唯一性
集合不允许重复的元素存在。

set3 = {1, 2, 2, 3, 3, 3}
print(set3)  

代码执行结果如下:

3.可变性
集合是可变的,您可以添加或删除元素。

set4 = {1, 2, 3}
set4.add(4)
print(set4)  

set4.remove(2)
print(set4) 

代码执行结果:

四、集合的操作

1.并集(Union)
获取两个集合中所有的唯一元素。

set5 = {1, 2, 3}
set6 = {3, 4, 5}
union_set = set5 | set6
print(union_set)  

代码执行结果:

2.交集(Intersection)
获取两个集合中共同存在的元素。

intersection_set = set5 & set6
print(intersection_set)  

代码执行结果:

3.差集(Difference)
获取在一个集合中存在但在另一个集合中不存在的元素。

difference_set = set5 - set6
print(difference_set) 

代码执行结果:

五、集合的应用场景

  1. 去除重复数据

data = [1, 2, 2, 3, 3, 3]
unique_data = list(set(data))
print(unique_data)  # 输出 [1, 2, 3]

代码执行结果:

成员检测
由于集合的查找效率高,适合快速判断一个元素是否在集合中。

membership_set = {10, 20, 30}
if 20 in membership_set:
    print("20 是集合的成员")

代码执行结果:

六、集合中的方法

方法的简单介绍:

方法描述
add()为集合添加元素
clear()移除集合中的所有元素
copy()拷贝一个集合
difference()返回多个集合的差集
difference_update()移除集合中的元素,该元素在指定的集合也存在。
discard()删除集合中指定的元素
intersection()返回集合的交集
intersection_update()返回集合的交集。
isdisjoint()判断两个集合是否包含相同的元素,如果没有返回 True,否则返回 False。
issubset()判断指定集合是否为该方法参数集合的子集。
issuperset()判断该方法的参数集合是否为指定集合的子集
pop()随机移除元素
remove()移除指定元素
symmetric_difference()返回两个集合中不重复的元素集合。
symmetric_difference_update()移除当前集合中在另外一个指定集合相同的元素,并将另外一个指定集合中不同的元素插入到当前集合中。
union()返回两个集合的并集
update()给集合添加元素
len()计算集合元素个数

以下是对这些集合方法的更详细解释:

add() 方法
这个方法用于向集合中添加一个新元素。集合的特点是不允许重复元素,所以如果添加的元素已经存在于集合中,不会产生任何效果。例如:

s = {1, 2}
s.add(3)
print(s)  # 输出: {1, 2, 3}
s.add(2)
print(s)  # 输出: {1, 2, 3}  因为 2 已存在,所以没有添加

clear() 方法
此方法会清空集合中的所有元素,将集合变为一个空集合。

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

copy() 方法
它创建并返回一个集合的独立副本。这意味着对原始集合的修改不会影响副本,反之亦然。

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

difference() 方法
返回一个新的集合,其中包含调用集合中存在但在指定的一个或多个集合中不存在的元素。

s1 = {1, 2, 3, 4}
s2 = {3, 4, 5}
print(s1.difference(s2))  # 输出: {1, 2}

difference_update() 方法
直接在原始集合上进行修改,移除在指定集合中也存在的元素。

s1 = {1, 2, 3, 4}
s2 = {3, 4, 5}
s1.difference_update(s2)
print(s1)  # 输出: {1, 2}

discard() 方法
删除集合中指定的元素,如果元素不存在,不会引发错误。

s = {1, 2, 3}
s.discard(2)
print(s)  # 输出: {1, 3}
s.discard(5)  # 不会报错

intersection() 方法
返回一个新的集合,其中包含两个或多个集合中共同存在的元素。

s1 = {1, 2, 3}
s2 = {2, 3, 4}
print(s1.intersection(s2))  # 输出: {2, 3}

intersection_update() 方法
直接在原始集合上修改,使其只保留与指定集合的交集。

s1 = {1, 2, 3}
s2 = {2, 3, 4}
s1.intersection_update(s2)
print(s1)  # 输出: {2, 3}

isdisjoint() 方法
判断两个集合是否没有共同的元素。如果没有共同元素,返回 True ;否则返回 False

s1 = {1, 2}
s2 = {3, 4}
print(s1.isdisjoint(s2))  # 输出: True
s3 = {2, 5}
print(s1.isdisjoint(s3))  # 输出: False

issubset() 方法
判断一个集合是否为另一个集合的子集。如果指定集合的所有元素都在参数集合中,则返回 True ;否则返回 False

s1 = {1, 2}
s2 = {1, 2, 3}
print(s1.issubset(s2))  # 输出: True

issuperset() 方法
判断一个集合是否是另一个集合的超集。如果参数集合的所有元素都在指定集合中,则返回 True ;否则返回 False

s1 = {1, 2, 3}
s2 = {1, 2}
print(s1.issuperset(s2))  # 输出: True

pop() 方法
随机移除并返回集合中的一个元素。如果集合为空,会引发 KeyError

s = {1, 2, 3}
print(s.pop())  # 输出随机一个元素,比如 2
print(s)  # 输出: {1, 3}

remove() 方法
移除集合中的指定元素,如果元素不存在,会引发 KeyError

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

symmetric_difference() 方法
返回两个集合中不重复的元素组成的新集合。

s1 = {1, 2, 3}
s2 = {2, 3, 4}
print(s1.symmetric_difference(s2))  # 输出: {1, 4}

symmetric_difference_update() 方法
在原始集合上修改,使其包含两个集合中不重复的元素。

s1 = {1, 2, 3}
s2 = {2, 3, 4}
s1.symmetric_difference_update(s2)
print(s1)  # 输出: {1, 4}

union() 方法
返回两个集合的并集,即包含两个集合中的所有不重复元素。

s1 = {1, 2, 3}
s2 = {2, 3, 4}
print(s1.union(s2))  # 输出: {1, 2, 3, 4}

update() 方法
将一个可迭代对象中的元素添加到集合中。

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

len() 方法
用于计算集合中元素的个数。

s = {1, 2, 3}
print(len(s))  # 输出: 3

七、总结

集合在 Python 中是一种非常有用的数据结构,凭借其无序、唯一和可变的特性,以及丰富的集合操作,能够帮助我们更高效地处理数据和解决问题。

制作不易,请多多三连,谢谢。

标签:Python,s2,s1,元素,print,深入,集合,difference
From: https://blog.csdn.net/weixin_61003764/article/details/140425336

相关文章

  • 《探索 Python 字典的奥秘》
    在Python中,字典(Dictionary)是一种非常强大和灵活的数据结构。它以键值对(Key-ValuePair)的形式存储数据,类似于现实生活中的字典,通过查找单词(键)来获取其释义(值)。一、字典的定义字典可以使用花括号 {} 来创建,键和值之间用冒号 : 分隔,键值对之间用逗号 , 分隔,dict 作为......
  • python中逻辑运算符and 和 or 的优先级问题。
    python的说明文档以及教材上、网上都说明and的优先级大于or。但我经过实际操作,发现其中规律似乎并不简单,下面我列举一些代码,来提出我的疑问:有时候or的优先级高,有时候and优先级高,并且并不是从左至右运算。首先说明python当中的and和or运算逻辑如下(这里必须懂):    1......
  • Python篇——继承及多重继承
    引言为什么要用到继承呢?因为继承可以减少代码冗余以及提高代码的重用性。1继承继承用于类的创建,继承描述类与类之间的关系新创建的类是子类,被继承的类是父类子类继承父类的属性和方法1.1场景条件——创建父类定义Person类,有两个属性:name和age,和一个方法greet,输出:Hi,......
  • Python篇——私有属性
    1私有属性的特点Python类中的私有属性是一种实现封装的方式,用于限制对某些属性的直接访问。以下是关于Python类中私有属性的主要特点:1.1命名约定使用双下划线(__)前缀来创建私有属性,例如‘ __private_attr’1.2名称改写(NameMangling)Python会自动将双下划线开头的属......
  • 运算式树(Expression tree)深入学习
    前言运算式树(Expressiontree)是二叉树数据结构。目的是实现方便的叠加各种查询条件,无限制的拼接成一个查询条件。提高复杂查询逻辑的编码效率。一、Lambda表达式Lambda表达式分为运算式Lambda和语句式Lambda下面用两种lambda实现同样功能的委托。(1)运算式Lambda(Expressionla......
  • 面试算法(排序)附带c++/python实现
            排序算法是面试中会经常会被问到的一类问题,如果可以掌握较多的排序算法,在面试过程中才更有机会被面试官看重哦,下面我们准备了一些常见的面试算法,并分别给出了c++和python的代码实现,小伙伴们一起学起来吧!冒泡排序(BubbleSort)        基于交换的排序,......
  • python 面试宝典
    50道必备的Python面试题(建议点赞)-阿里云开发者社区(aliyun.com) ▍2、为什么Python执行速度慢,我们如何改进它?Python代码执行缓慢的原因,是因为它是一种解释型语言。它的代码在运行时进行解释,而不是编译为本地语言。为了提高Python代码的速度,我们可以使用CPython、Numba,或......
  • 基于小波分析的糖尿病视网膜病变检测(Python)
    fromscipyimportmiscfromPILimportImagefromskimageimportexposurefromsklearnimportsvmimportscipyfrommathimportsqrt,pifromnumpyimportexpfrommatplotlibimportpyplotaspltimportnumpyasnpimportglobimportmatplotlib.pyplotas......
  • 简单的小波分析入门教程(第一部分,Python)
    importnumpyasnpimportmatplotlib.pyplotaspltimportpywtSimpleSignalAnalysisusingDWT#Generatethesignalt=np.linspace(0,1,1000,endpoint=False)signal=np.cos(2.0*np.pi*7*t)+np.sin(2.0*np.pi*13*t)#ApplyDWTcoeffs=p......
  • Python数据库应用
      通过文件操作可以实现简单的数据操作功能,如果要处理的数据量巨大,则需要将数据存储在数据库中。Python支持多种数据库。  本章主要介绍数据库概念以及结构化数据库查询语言SQL,分析并理解Python自带的轻量级关系数据库SQLlite的使用方法(同样用于MySQL数据库)  文......