一般来说,python中常用的数据结构是:列表(list)、字典(Dict)、元组(tuple)。但是我们常常还会看到另外一种结构:集合(set)。 个人认为,字典(dict)就是一种特殊的集合(set),它特殊的地方是集合的元素之间有一对一的对应关系。 集合,在定义上来说就是无序不重复的元素集,set里面可以是多种数据类型(但不能是列表,集合,字典,可以是元组)。 需要注意的是集合是无序的,所以不能用下标来访问。
## 1. 集合的创建
m = [1,2,9,6,3,4,6,7,8,7,6,4]
a = set(m)
print(a)
打印结果:
{1, 2, 3, 4, 6, 7, 8, 9}
## 2 集合的操作(s 代表一个集合) - 2.1 s.add( x ) 将元素 x 添加到集合s中,若重复则不进行任何操作
m = [1,2,9,6,3,4,6,7,8,7,6,4]
s = set(m)
s.add(7)
print(s)
s.add(10)
print(s)
打印结果:
{1, 2, 3, 4, 6, 7, 8, 9}
{1, 2, 3, 4, 6, 7, 8, 9, 10}
m = [1,2,9,6,3,4,6,7,8,7,6,4]
s = set(m)
x = {11,5,45}
s.update(x)
print(s)
打印结果:
{1, 2, 3, 4, 5, 6, 7, 8, 9, 11, 45}
m = [1,2,9,6,3,4,6,7,8,7,6,4]
s = set(m)
s.discard(5)
s.discard(77)
print(s)
打印结果:
{1, 2, 3, 4, 6, 7, 8, 9}
m = [1,2,9,6,3,4,6,7,8,7,6,4]
s = set(m)
s.remove(4)
print(s)
s.remove(5)
print(s)
打印结果:
{1, 2, 3, 6, 7, 8, 9}
Traceback (most recent call last):
File "D:/home/temp/temp_set.py", line 5, in <module>
s.remove(5)
KeyError: 5
可以看出discard和remove的区别。
m = [1,2,9,6,3,4,6,7,8,7,6,4]
s = set(m)
s.pop()
print(s)
s.pop()
print(s)
clear():清空
in操作
union( x ) 返回s与集合x的交集,不改变原集合s,x 也可以是列表,元组,字典。
intersection( x ) 返回s与集合x的并集,不改变s, x 也可以是列表,元组,字典。
difference( x )返回在集合s中而不在集合 x 中的元素的集合,不改变集合s, x 也可以是列表,元组,字典。
s.symmetric_difference( x ) 返回s和集合x的对称差集,即只在其中一个集合中出现的元素,不改变集合s, x 也可以是列表,元组,字典。
s.issubset( x ) 判断 集合s 是否是 集合x 子集
s.issuperset( x ) 判断 集合x 是否是集合s的子集