集合

本文详细介绍了Python中集合的定义、创建、关系运算及常用函数,包括add、pop、remove等方法,以及交集、并集、差集和对称差集的使用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

1.定义集合

  定义:不同的元素组成,无序排列的可hash的值,可以理解为k值

    特性:不同的元素存放到一起集合间进行关系运算,不用考虑如何把元素取出来。

2.集合创建

 可变集合:
>>> set_test=set('hello')
>>> set_test
 改为不可变集合:
forset = frozenset(set_test)

3.集合关系运算

    in
not in
==
!=
<,<=
>,>=
|,|=:合集
&.&=:交集
-,-=:差集
^,^=:对称差分

4.集合常用函数

  linuxs={'wupeiqi','oldboy','tiedan'}

  linuxs.add() 

1 linuxs.add('laowang')
2 print(linuxs)
3 #{'wupeiqi', 'laowang', 'tiedan', 'oldboy'}

  linuxs.pop()

1 linuxs.pop() 
2 print(linuxs) 
3 #{'oldboy', 'wupeiqi'}(随机取)有返回值 

  linuxs.remove()

1 linuxs.remove('oldboy')
2 print(linuxs)
3 #{'tiedan', 'wupeiqi'} 没有返回值,没有的值会报错

  linuxs.discard()

1 linuxs.discard('oldboyklkl')
2 print(linuxs)
3 #{'wupeiqi', 'tiedan', 'oldboy'} 没有的值不会报错,没有返回值

  linuxs.update()

1 linuxs.update('oldboyklkl')
2 print(linuxs)
3 #更新到原先集合中

  linuxs.clear()

1 linuxs.clear()
2 print(linuxs)
3 #set()  空集合

  linuxs.copy()

1 a = linuxs.copy()
2 linuxs.clear()#删除以后,集合a仍然可以打印出来
3 print(a)
4 #{'tiedan', 'oldboy', 'wupeiqi'}

  linuxs.diference_update()

1 linuxs.difference_update({'okay','tiedan'})
2 print(linuxs)
3 #去掉原先集合中与第二个集合元素的交集,更新到原先集合中,对第二个集合没有影响,{'oldboy', 'wupeiqi'}

    linuxs.discard()

1 linuxs ={'wupeiqi','oldboy','tiedan','niucha','yy'}
2 linuxs.discard('oldboylll')
3 print(linuxs) #{'oldboy', 'yy', 'wupeiqi', 'niucha', 'tiedan'}
4 #去掉第一个集合与第二个集合的交集,没有返回值

     linuxs.intersection()

 

1 linuxs ={'wupeiqi','oldboy','tiedan','niucha','yy','xx'}
2 liu = linuxs.intersection({'niucha','oldboy','xx'})
3 print(liu) 
4 #{'niucha', 'xx', 'oldboy'} 
5 #取两个集合的交集,并返回一个新的集合

 

    linuxs.intersection_update()

1 linuxs ={'wupeiqi','oldboy','tiedan','niucha','yy','xx'}
2 linuxs.intersection_update({'niucha','oldboy','xx'})
3 print(linuxs)
4 #{'oldboy', 'xx', 'niucha'}
5 #两个集合的交集组成一个新的集合,并更新到第一个集合中,没有返回值

    linuxs.isdisjoint()

1 linuxs ={'wupeiqi','oldboy','tiedan','niucha','yy','xx'}
2 liu = linuxs.isdisjoint({'niucha','oldboy','xx'})
3 #False
4 #判断两个集合的交集是否为空,如果不为空,返回False

     linuxs.issubset()

1 linuxs ={'wupeiqi','oldboy','tiedan','niucha','yy','xx'}
2 b = linuxs.issubset({'wupeiqi','oldboy','tiedan','niucha','yy','xx','aaa'})
3 print(b)#True
4 #判断第一个集合是否含于第二个集合,即s1 <= s2

    linuxs.issuperset()

1 linuxs ={'wupeiqi','oldboy','tiedan','niucha','yy','xx'}
2 liu = linuxs.issuperset({'niucha','oldboy','xx'})
3 print(liu) #True 
4 #判断第一个集合是否完全包含第二个集合,如果完全包含返回Ture,否则返回False

      linuxs.symmetric_difference()

1 linuxs ={'wupeiqi','oldboy','tiedan','niucha','yy','xx'}
2 liu = linuxs.symmetric_difference({'niucha','oldboy','ccc'})
3 print(liu) #{'tiedan', 'wupeiqi', 'xx', 'ccc', 'yy'}
4 #去掉两个集合的差值,将两个集合的非交集组成一个新的集合并返回

   linuxs.symmetric_difference_update()

1 linuxs ={'wupeiqi','oldboy','tiedan','niucha','yy','xx'}
2 linuxs.symmetric_difference_update({'niucha','oldboy','ccc'})
3 print(linuxs)#{'wupeiqi', 'xx', 'yy', 'ccc', 'tiedan'}
4 #去掉两个集合的交集,并把第二个集合中的元素更新到第一个集合中,组成一个新的集合

   linuxs.union()

1 linuxs ={'wupeiqi','oldboy','tiedan','niucha','yy','xx'}
2 liu = linuxs.union({'niucha','oldboy','ccc'})
3 print(liu) #{'wupeiqi', 'tiedan', 'xx', 'oldboy', 'niucha', 'yy', 'ccc'}
4 # 将两个集合的元素组成一个新的集合

 

转载于:https://www.cnblogs.com/sxh-myblogs/p/7217881.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值