脚本专栏 
首页 > 脚本专栏 > 浏览文章

Python集合操作方法详解

(编辑:jimmy 日期: 2025/1/16 浏览:3 次 )

集合是无序的,天生不重复的数据组合,它的作用如下:

  • 去重,即:把一个列表变成集合,就去重了
  • 关系测试,即:测试两组集合的交集、并集和差集等

一、集合常用方法总结

Python集合操作方法详解

二、定义

1、语法

> name_1 = [1,2,3,4,7,8,7,10]
#把列表转换为集合
> name_1 = set(name_1)
#转换后,去重
> print(name_1,type(name_1))
{1, 2, 3, 4, 7, 8, 10} <class 'set'>

"htmlcode">
> name_1 = [1,2,3,4,7,8,7,10]
> name_2 = [1,3,5,8,10]
> name_1 = set(name_1)
> name_2 = set(name_2)
#输出结果
> name_1.intersection(name_2)
{8, 1, 10, 3}

2、并集(union())

> name_1 = [1,2,3,4,7,8,7,10]
> name_2 = [1,3,5,8,10]
> name_1 = set(name_1)
> name_2 = set(name_2)
#输出结果
> name_1.union(name_2)
{1, 2, 3, 4, 5, 7, 8, 10}

"htmlcode">
> name_1 = [1,2,3,4,7,8,7,10]
> name_2 = [1,3,5,8,10]
> name_1 = set(name_1)
> name_2 = set(name_2)
#输出结果
> name_1.difference(name_2)
{2, 4, 7}

"htmlcode">
> name_1 = [1,2,3,4,7,8,7,10]
> name_3 = [1,2,3,4]
> name_1 = set(name_1)
> name_3 = set(name_3)
#输出结果
> name_3.issubset(name_1)
True

"htmlcode">
> name_1 = [1,2,3,4,7,8,7,10]
> name_3 = [1,2,3,4]
> name_1 = set(name_1)
> name_3 = set(name_3)
#输出结果
> name_1.issuperset(name_3)
True

"htmlcode">
> name_1 = [1,2,3,4,7,8,7,10]
> name_2 = [1,3,5,8,10]
> name_1 = set(name_1)
> name_2 = set(name_2)
#输出结果
> name_1.symmetric_difference(name_2)
{2, 4, 5, 7}

"htmlcode">
> name_1 = [1,2,3,4,7,8,7,10]
> name_2 = [1,3,5,8,10]
> name_3 = [11]
> name_1 = set(name_1)
> name_2 = set(name_2)
> name_3 = set(name_3)
#有交集
> name_1.isdisjoint(name_2)
False
#无交集
> name_1.isdisjoint(name_3)
True

"htmlcode">
> name_1 = [1,2,3,4,7,8,7,10]
> name_2 = [1,3,5,8,10]
> name_1 = set(name_1)
> name_2 = set(name_2)
#结果输出
> name_1 & name_2
{8, 1, 10, 3}

2、并集(|)

> name_1 = [1,2,3,4,7,8,7,10]
> name_2 = [1,3,5,8,10]
> name_1 = set(name_1)
> name_2 = set(name_2)
#结果输出
> name_1 | name_2
{1, 2, 3, 4, 5, 7, 8, 10}

"htmlcode">
> name_1 = [1,2,3,4,7,8,7,10]
> name_2 = [1,3,5,8,10]
> name_1 = set(name_1)
> name_2 = set(name_2)
#结果输出
> name_1 - name_2
{2, 4, 7}

4、对称差集(^)

> name_1 = [1,2,3,4,7,8,7,10]
> name_2 = [1,3,5,8,10]
> name_1 = set(name_1)
> name_2 = set(name_2)
#输出
> name_1 ^ name_2
{2, 4, 5, 7}

5、是否是子集(<=)

> name_1 = [1,2,3,4,7,8,10]
> name_3 = [1,2,3,4]
> name_1 = set(name_1)
> name_3 = set(name_3)
#输出
> name_3 <= name_1
True

6、是否是父集(>=)

> name_1 = [1,2,3,4,7,8,10]
> name_3 = [1,2,3,4]
> name_1 = set(name_1)
> name_3 = set(name_3)
#输出
> name_1 >= name_3
True

"htmlcode">
> name_2 = [1,3,5,8,10]
> name_2 = set(name_2)
#添加已存在,不报错
> name_2.add(1)
> name_2
{8, 1, 10, 3, 5}
#添加不存在,添加一个新的数值
> name_2.add(11)
> name_2
{1, 3, 5, 8, 10, 11}

"htmlcode">
> name_2 = [1,3,5,8,10]
> name_2 = set(name_2)
> name_2.update([12,13,14])
#输出结果
> name_2
{1, 3, 5, 8, 10, 12, 13, 14}

"htmlcode">
> name_2 = [1,3,5,8,10]
> name_2 = set(name_2)
> name_2
{8, 1, 10, 3, 5}
> name_2.remove(1)
#输出
> name_2
{8, 10, 3, 5}
#删除不存在的元素,会报错
> name_2.remove(1)
Traceback (most recent call last):
 File "<input>", line 1, in <module>
KeyError: 1

"htmlcode">
> name_2 = [1,3,5,8,10]
> name_2 = set(name_2)
> name_2
{8, 1, 10, 3, 5}
#输出
> name_2.pop()
8

"htmlcode">
> name_2 = [1,3,5,8,10]
> name_2 = set(name_2)
> name_2.discard(10)
#输出结果
> name_2
{8, 1, 3, 5}
#删除不存在元素,不报错
> name_2.discard(10)

特别提示:用discard删除不存在的元素,不会出现报错

4、长度(len())

> name_1 = [1,2,3,4,7,8,7,10]
> name_1 = set(name_1)
#结果输出
> len(name_1)
7

"htmlcode">
> name_1 = [1,2,3,4,7,8,7,10]
> name_1 = set(name_1)
#结果输出
> 1 in name_1
True

"htmlcode">
> name_1 = [1,2,3,4,7,8,7,10]
> name_1 = set(name_1)
#输出
> 12 not in name_1
True

更多关于Python集合操作方法可查看下面的相关链接

上一篇:python字符串替换re.sub()实例解析
下一篇:Python随机数函数代码实例解析
一句话新闻
高通与谷歌联手!首款骁龙PC优化Chrome浏览器发布
高通和谷歌日前宣布,推出首次面向搭载骁龙的Windows PC的优化版Chrome浏览器。
在对骁龙X Elite参考设计的初步测试中,全新的Chrome浏览器在Speedometer 2.1基准测试中实现了显著的性能提升。
预计在2024年年中之前,搭载骁龙X Elite计算平台的PC将面世。该浏览器的提前问世,有助于骁龙PC问世就获得满血表现。
谷歌高级副总裁Hiroshi Lockheimer表示,此次与高通的合作将有助于确保Chrome用户在当前ARM兼容的PC上获得最佳的浏览体验。
友情链接:杰晶网络 DDR爱好者之家 南强小屋 黑松山资源网 白云城资源网 站点导航 SiteMap