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 # 将两个集合的元素组成一个新的集合