集合

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