Python——集合是一个非常之牛逼的数据比较方式

简介:

    什么是集合?对似懂非懂或者被集合搞晕了的同学可以来看一下。
    首先不想说太多概念性的东西,免得又晕了!

    请看下面我写的例子,看完之后自然就知道啥是集合以及如何去应用它

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#变量a是一个集合类型
=  set ()
print ( type (a))
 
#定义一个列表,并存入很多重复的数字
dt  =  [ 12 , 9 , 2 , 8 , 4 , 9 , 2 , 7 , 4 , 5 , 6 , 11 , 5 , 7 , 5 , 7 , 9 , 8 , 7 , 2 ]
for  in  dt:  #遍历列表
     a.add(i)  #将列表中的每一个元素添加进集合
 
#打印集合,发现,自动去掉重复的数字了
print (a)
 
#5存在于集合中吗?
print ( 5  in  a)
 
#遍历集合
for  item  in  a:
     print (item)
 
#将集合转化成列表
set_list  =  list (a)
print (set_list)
print ( type (set_list))


那么,集合还涉及到下面几个牛逼的玩意:

并集:
    它将两个集合作为参数,并返回一个包含全部存在于两个集合中任意一个的元素的新集合,用union()方法, 操作符是:"|"
交集:
    它接收第2个集合为参数,返回的是仅包含同时存在于两个集合的那些元素,intersection方法实现,操作符是:"&"
差集:
    它告诉我们哪些是剩下的元素,它是一个存储于或是存在于这个集合或是另一个集合,但不是同时存在于两个集合的对象的集合
    symmetric_difference方法实现,操作符是:"-"


继续看例子

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
=  { 1 , 2 , 3 , 4 , 5 }
=  { 6 , 2 , 3 , 7 }
 
#求a和b的并集,将两组数据中共同存在的数字去除掉后,生成一个不存在重复数字的新集合
print (a.union(b))
 
#求a和b的交集,将两组数据中共有的数字提取出来,并生成一个新的集合,让我们知道这两组数据中哪些数字都存在于两组数据里
print (a.intersection(b))
 
#求a和b的差集,将两组数据中所没有的数字提取出来后,生成一个新的集合
print (a.symmetric_difference(b))
 
#注意:他们的结果取决于谁是调用者,谁是参数,上面的3条例子中,a集合是调用者,b集合是参数
 
#a集合中的所有数字都存在于b集合的话,则返回true, a是调用者,b是参数
print (a.issubset(b))
 
#b集合作为参数,b集合中的所有元素都存在于a集合中的话,返回true
print (a.issuperset(b))
 
#想要知道全部只存在于a集合而不存在于b集合的元素
print (a.difference(b))  #结果是1,4,5
#反之
print (b.difference(a))  #结果是6和7


总结:
    通过测试说明,集合可以用来操作另一个集合,集合不仅仅只是一个容器
    那么,应用场景一般有如下:
        1、对两处不同的数据,如果要快速的结合起来去做分析,那么请用集合
        2、那么快速的结合起来的目的一般是干嘛呢?,比如想知道两处数据中哪些是重复的,哪些是不同的
        
因此:
    集合是一个非常之牛逼的数据比较方式


本文转自 TtrToby 51CTO博客,原文链接:http://blog.51cto.com/freshair/2064765


相关文章
|
2天前
|
存储 JSON 数据库
Python中列表数据的保存与读取:以txt文件为例
Python中列表数据的保存与读取:以txt文件为例
14 2
|
2天前
|
Python
【Python操作基础】——集合
【Python操作基础】——集合
|
2天前
|
XML 前端开发 数据格式
BeautifulSoup 是一个 Python 库,用于从 HTML 和 XML 文件中提取数据
【5月更文挑战第10天】BeautifulSoup 是 Python 的一个库,用于解析 HTML 和 XML 文件,即使在格式不规范的情况下也能有效工作。通过创建 BeautifulSoup 对象并使用方法如 find_all 和 get,可以方便地提取和查找文档中的信息。以下是一段示例代码,展示如何安装库、解析 HTML 数据以及打印段落、链接和特定类名的元素。BeautifulSoup 还支持更复杂的查询和文档修改功能。
21 1
|
21小时前
|
Web App开发 JSON JavaScript
利用 python 分析基金,合理分析数据让赚钱赢在起跑线!(1)
利用 python 分析基金,合理分析数据让赚钱赢在起跑线!(1)
|
2天前
|
存储 JSON 数据格式
Python知识点——高维数据的格式化
Python知识点——高维数据的格式化
5 0
|
2天前
|
Python
Python知识点——文件和数据格式化
Python知识点——文件和数据格式化
5 0
|
2天前
|
存储 机器学习/深度学习 数据可视化
基于Python的数据分组技术:将数据按照1, 2, 3规则分为三个列表
基于Python的数据分组技术:将数据按照1, 2, 3规则分为三个列表
8 1
|
2天前
|
存储 JSON 数据挖掘
python序列化和结构化数据详解
python序列化和结构化数据详解
13 0
|
2天前
|
数据采集 数据可视化 数据挖掘
Python 与 PySpark数据分析实战指南:解锁数据洞见
Python 与 PySpark数据分析实战指南:解锁数据洞见
|
2天前
|
数据采集 数据处理 开发者
Python 中的数据处理技巧:高效数据操作的艺术
Python 在数据处理方面表现卓越,为开发者提供了丰富的工具和库以简化数据操作。在本文中,我们将探讨 Python 中数据处理的一些技巧,包括数据清洗、数据转换以及优化数据操作的最佳实践。通过掌握这些技巧,您可以在 Python 中更加高效地处理和分析数据。