Python set集合
一、 set集合概述
①set集合,是一个无序且不重复的元素集合。
②集合对象是一组无序排列的可哈希的值,集合成员可以做字典中的键。
③集合支持用in和not in操作符检查成员,由len()内建函数得到集合的基数(大小), 用 for 循环迭代集合的成员。但是因为集合本身是无序的,不可以为集合创建索引或执行切片(slice)操作,也没有键(keys)可用来获取集合中元素的值。
④集合set是Python中一种基本数据类型,它分为可变集合(set)和不可变集合(frozenset)两种。
二、set的操作
1. set的创建
集合中set括号中需要的参数的数据类型有:序列(包括字符串、列表、元组),字典或者是另一个集合,但是不能是数值类型,如int类型。
s1=() #创建空集合set()
print(s1)
s2=set(['carlos','alex','eric','tony']) #列表做参数
print(s2)
s3=set('carlos')#字符串做参数
print(s3)
s4=set((1,2,3))#元组做参数
print(s4)
s5=set({'name':'carlos','age':'26'})#元组做参数 , 只取值字典中的key
print(s5)
输出
()
{'tony', 'carlos', 'alex', 'eric'}
{'l', 'o', 'a', 's', 'r', 'c'}
{1, 2, 3}
{'age', 'name'}
s=set(['carlos','alex','eric','tony','carlos']) #set中的元素是无序不重复 的,可以利用这个特点去除列表中的重复元素
print(s)
输出
{'alex', 'carlos', 'tony', 'eric'}
2. set集合的添加
2.1 add(self, *args, **kwargs)把要传入的元素作为一个整体添加到集合中
s=set(['carlos','alex','eric','tony'])
print(s)
s.add('gary')
print(s)
输出
{'tony', 'carlos', 'alex', 'eric'}
{'tony', 'alex', 'gary', 'eric', 'carlos'}
2.2 update(self, *args, **kwargs) 要传入的元素拆分成单个字符,存于集合中,并去掉重复的字符
s=set(['carlos','alex','eric','tony'])
print(s)
s.update('amy')
print(s)
输出
{'tony', 'carlos', 'alex', 'eric'}
{'a', 'm', 'eric', 'tony', 'y', 'carlos', 'alex', 'gary'}
3.集合的删除
集合的删除操作使用的方法跟列表是一样的,使用的也是remove方法,若不存在,报错
s=set(['carlos','alex','eric','tony'])
print(s)
s.remove('alex')
print(s)
输出
{'tony', 'eric', 'alex', 'carlos'}
{'tony', 'eric', 'carlos'}
4. 集合的遍历
s=set(['carlos','alex','eric','tony'])
for i in s:
print(i)
输出
tony
eric
alex
carlos
s=set(['carlos','alex','eric','tony'])
for idx, i in enumerate(s) :
print(idx,i)
输出
0 tony
1 alex
2 eric
3 carlos
三、集合的一些操作符
1.交集 python中求集合的交集使用的符号是“&”,返回连个集合的共同元素的集合,即集合的交集。
s1=set('carlos')
print(s1)
s2=set('alex')
print(s2)
s=s1&s2
print(s)
输出
{'o', 's', 'r', 'c', 'l', 'a'}
{'x', 'l', 'a', 'e'}
{'l', 'a'}
2.并集(合集) Python中求集合的并集用的是符号“|”,返回的是两个集合所有的并去掉重复的元素的集合。
s1=set('carlos')
print(s1)
s2=set('alex')
print(s2)
s=s1|s2
print(s)
输出
{'s', 'r', 'c', 'o', 'l', 'a'}
{'e', 'l', 'a', 'x'}
{'s', 'x', 'r', 'c', 'o', 'e', 'l', 'a'}
3.差集 Python中差集使用的符号是减号“-” ,返回的结果是在集合st1中但不在集合s2中的元素的集合
s1=set('carlos')
print(s1)
s2=set('alex')
print(s2)
s=s1-s2
print(s)
输出
{'l', 's', 'r', 'a', 'c', 'o'}
{'a', 'l', 'x', 'e'}
{'r', 'c', 's', 'o'}
4.查看两个集合的不同之处,使用的difference函数,等价于差集
不同指的是集合s3相对于集合s1,不同的地方,也就是所有在集合s1中,而不再集合s2中的的元素组成的新集合。
s1=set('carlos')
s2=set('alex')
s=s1-s2
s3=s1.difference(s2)
print(s)
print(s3)
输出
{'r', 'o', 'c', 's'}
{'r', 'o', 'c', 's'}
5. 集合的范围判断
集合可以使用大于(>)、小于(<)、大于等于(>=)、小于等于(<=)、等于(==)、不等于(!=)来判断某个集 合是否完全包含于另一个集合,也可以使用子父集判断函数。 返回值为True 或者False。
6. 集合的成员运算符 使用成员运算符,in和not in,判断某个对象是否是集合中的成员
s1=([1,2,3,4,5,])
result=1 in s1
print(result)
result=4 not in s1
print(result)
输出
True
False
7. 求集合的长度 使用len()函数
s1=([1,2,3,4,5,])
result=len(s1)
print(result)
输出 5
四、set的方法
class set(object):
"""
set() -> new empty set object
set(iterable) -> new set object Build an unordered collection of unique elements.
"""
def add(self, *args, **kwargs): # real signature unknown
"""
Add an element to a set. This has no effect if the element is already present.
"""
pass def clear(self, *args, **kwargs): # real signature unknown
""" Remove all elements from this set. """
pass def copy(self, *args, **kwargs): # real signature unknown
""" Return a shallow copy of a set. """
pass def difference(self, *args, **kwargs): # real signature unknown
"""
Return the difference of two or more sets as a new set. (i.e. all elements that are in this set but not the others.)
"""
pass def difference_update(self, *args, **kwargs): # real signature unknown
""" Remove all elements of another set from this set. """
pass def discard(self, *args, **kwargs): # real signature unknown
"""
Remove an element from a set if it is a member. If the element is not a member, do nothing.
"""
pass def intersection(self, *args, **kwargs): # real signature unknown
"""
Return the intersection of two sets as a new set. (i.e. all elements that are in both sets.)
"""
pass def intersection_update(self, *args, **kwargs): # real signature unknown
""" Update a set with the intersection of itself and another. """
pass def isdisjoint(self, *args, **kwargs): # real signature unknown
""" Return True if two sets have a null intersection. """
pass def issubset(self, *args, **kwargs): # real signature unknown
""" Report whether another set contains this set. """
pass def issuperset(self, *args, **kwargs): # real signature unknown
""" Report whether this set contains another set. """
pass def pop(self, *args, **kwargs): # real signature unknown
"""
Remove and return an arbitrary set element.
Raises KeyError if the set is empty.
"""
pass def remove(self, *args, **kwargs): # real signature unknown
"""
Remove an element from a set; it must be a member. If the element is not a member, raise a KeyError.
"""
pass def symmetric_difference(self, *args, **kwargs): # real signature unknown
"""
Return the symmetric difference of two sets as a new set. (i.e. all elements that are in exactly one of the sets.)
"""
pass def symmetric_difference_update(self, *args, **kwargs): # real signature unknown
""" Update a set with the symmetric difference of itself and another. """
pass def union(self, *args, **kwargs): # real signature unknown
"""
Return the union of sets as a new set. (i.e. all elements that are in either set.)
"""
pass def update(self, *args, **kwargs): # real signature unknown
""" Update a set with the union of itself and others. """
pass def __and__(self, *args, **kwargs): # real signature unknown
""" Return self&value. """
pass def __contains__(self, y): # real signature unknown; restored from __doc__
""" x.__contains__(y) <==> y in x. """
pass def __eq__(self, *args, **kwargs): # real signature unknown
""" Return self==value. """
pass def __getattribute__(self, *args, **kwargs): # real signature unknown
""" Return getattr(self, name). """
pass def __ge__(self, *args, **kwargs): # real signature unknown
""" Return self>=value. """
pass def __gt__(self, *args, **kwargs): # real signature unknown
""" Return self>value. """
pass def __iand__(self, *args, **kwargs): # real signature unknown
""" Return self&=value. """
pass def __init__(self, seq=()): # known special case of set.__init__
"""
set() -> new empty set object
set(iterable) -> new set object Build an unordered collection of unique elements.
# (copied from class doc)
"""
pass def __ior__(self, *args, **kwargs): # real signature unknown
""" Return self|=value. """
pass def __isub__(self, *args, **kwargs): # real signature unknown
""" Return self-=value. """
pass def __iter__(self, *args, **kwargs): # real signature unknown
""" Implement iter(self). """
pass def __ixor__(self, *args, **kwargs): # real signature unknown
""" Return self^=value. """
pass def __len__(self, *args, **kwargs): # real signature unknown
""" Return len(self). """
pass def __le__(self, *args, **kwargs): # real signature unknown
""" Return self<=value. """
pass def __lt__(self, *args, **kwargs): # real signature unknown
""" Return self<value. """
pass @staticmethod # known case of __new__
def __new__(*args, **kwargs): # real signature unknown
""" Create and return a new object. See help(type) for accurate signature. """
pass def __ne__(self, *args, **kwargs): # real signature unknown
""" Return self!=value. """
pass def __or__(self, *args, **kwargs): # real signature unknown
""" Return self|value. """
pass def __rand__(self, *args, **kwargs): # real signature unknown
""" Return value&self. """
pass def __reduce__(self, *args, **kwargs): # real signature unknown
""" Return state information for pickling. """
pass def __repr__(self, *args, **kwargs): # real signature unknown
""" Return repr(self). """
pass def __ror__(self, *args, **kwargs): # real signature unknown
""" Return value|self. """
pass def __rsub__(self, *args, **kwargs): # real signature unknown
""" Return value-self. """
pass def __rxor__(self, *args, **kwargs): # real signature unknown
""" Return value^self. """
pass def __sizeof__(self): # real signature unknown; restored from __doc__
""" S.__sizeof__() -> size of S in memory, in bytes """
pass def __sub__(self, *args, **kwargs): # real signature unknown
""" Return self-value. """
pass def __xor__(self, *args, **kwargs): # real signature unknown
""" Return self^value. """
pass __hash__ = None
set源码
1、add(self, *args, **kwargs) 将元素 添加到集合s中,若重复则不进行任何操作
update(self, *args, **kwargs) 将集合 x 并入原集合s中,x 还可以是列表,元组,字典等,x 可以有多个,用逗号分开
2、clear(self, *args, **kwargs) 删除 set 中的所有元素
3、copy(self, *args, **kwargs) 复制集合
4、difference(self, *args, **kwargs) 返回一个新的 set 包含 s1中有但是s2中没有的元素(生成新集合,不改变原集合)
difference_update(self, *args, **kwargs) 返回一个新的 set 包含 s1和 s2中不重复的元素(改变原集合)
s1=set('carlosalexamy')
s2=set('alextong')
s3=s1.difference(s2)
s4=s1.difference_update(s3)
print(s3)
print(s4)
输出
{'s', 'c', 'm', 'r', 'y'}
None
5、discard(self, *args, **kwargs) 如果在 set “s”中存在元素 x, 则删除。若不存在,不会引发错误
s1=set(['carlos','alex','eric','tony'])
s1.discard('tony')
print(s1)
输出{'carlos', 'alex', 'eric'}
6、intersection(self, *args, **kwargs) 取交集,新建一个set
intersection_update(self, *args, **kwargs) 取交集,修改原来set
7. isdisjoint(self, *args, **kwargs) 如果没有交集,返回Ture
8. issubset(self, *args, **kwargs) 是否是子集
9. issuperset(self, *args, **kwargs) 是否是父集
10. pop(self, *args, **kwargs) 删除并且返回 set “s”中的一个不确定的元素, 如果为空则引发 KeyError (在原集合拿走一个随机元素,并得到这个元素, 这个是两个动作)
s1=set(['carlos','alex','eric','tony'])
result=s1.pop()
print(s1)
print(result)
输出
{'carlos', 'tony', 'alex'}
eric
11. remove(self, *args, **kwargs) 从 set “s”中删除元素 x, 如果不存在则引发 KeyError(在原集合拿走一个指定元素,无返回值)
s1=set(['carlos','alex','eric','tony'])
result=s1.remove('alex')
print(s1)
print(result)
输出
{'carlos', 'tony', 'eric'}
None
12. symmetric_difference(self, *args, **kwargs) 取差集,新建一个set
symmetric_difference_update(self, *args, **kwargs) 取差集,改变原来set
13. union(self, *args, **kwargs) 取并集
五、 举例子