集合
集合(set)是一个无序的不重复元素序列。可以使用大括号 { } 或者 set() 函数创建集合,注意:创建一个空集合必须用 set() 而不是 { },因为 { } 是用来创建一个空字典。
创建格式:
parame = {value01,value02,…}
或者
set(value)
集合的基本操作
- 将元素添加进集合
s.add( x )
ps:将元素 x 添加到集合 s 中,如果元素已存在,则不进行任何操作。
s.update(x)
thisset = set((“Google”, “Runoob”, “Taobao”))
thisset.update({1,3})
print(thisset)
输出结果:{1, 3, ‘Google’, ‘Taobao’, ‘Runoob’}
- 移除元素
s.remove(x)
thisset = set((“Google”, “Runoob”, “Taobao”))
thisset.remove(“Taobao”)
print(thisset)
输出结果:{‘Google’, ‘Runoob’}ps:当删除的结果不存在时会进行相应的报错行为。
s.discard( x )
另一个删除函数,用法以及方法和remove相似
s.pop( )
随机删除一个元素,每次执行的结果都不一样。
- 计算集合元素的个数
len(s)
thisset = set((“Google”, “Runoob”, “Taobao”))
len(thisset)
3
- set.difference(set)
返回集合的差集,集返回在第一个集合中但是不再第二个集合之中的元素
x = {“apple”, “banana”, “cherry”}
y = {“google”, “microsoft”, “apple”}
z = x.difference(y)
print(z)
结果是: {‘cherry’, ‘banana’}
- difference_update()
difference_update() 方法用于移除两个集合中都存在的元素。
difference_update() 方法与 difference() 方法的区别在于 difference() 方法返回一个移除相同元素的新集合,而 difference_update() 方法是直接在原来的集合中移除元素,没有返回值。实例
x = {“apple”, “banana”, “cherry”}
y = {“google”, “microsoft”, “apple”}
x.difference_update(y)
print(x)
输出结果为:
{‘cherry’, ‘banana’}
- intersection()
intersection() 方法用于返回两个或更多集合中都包含的元素,即交集。
用法:set.intersection(set1, set2 … etc)
参数
set1 – 必需,要查找相同元素的集合
set2 – 可选,其他要查找相同元素的集合,可以多个,多个使用逗号 , 隔开
返回值
返回一个新的集合。
实例
返回一个新集合,该集合的元素既包含在集合 x 又包含在集合 y 中:
实例 1
x = {“apple”, “banana”, “cherry”}
y = {“google”, “runoob”, “apple”}
z = x.intersection(y)
print(z)输出结果为:
{‘apple’}
- intersection_update()
intersection_update() 方法用于获取两个或更多集合中都重叠的元素,即计算交集。
intersection_update() 方法不同于 intersection() 方法,因为 intersection() 方法是返回一个新的集合,而 intersection_update() 方法是在原始的集合上移除不重叠的元素。
- isdisjoint()
isdisjoint()方法用于判断两个集合是否包含相同的元素,如果没有返回true,否则返回false
实例 1
x = {“apple”, “banana”, “cherry”}
y = {“google”, “runoob”, “facebook”}
z = x.isdisjoint(y)
print(z)
输出结果为:
True