转载 原文Python学习之路day3-集合:https://www.cnblogs.com/linupython/p/6561700.html
# 集合set
# 无序且不重复的序列
# 应用场景:去重处理;关系测试
1、创建集合
s1={11,22,33}
s2=set()
s3=set([11,22,44,22]) # 自动去重
print(s1)
print(s2)
print(s3)
2、元素对象常见操作
# add(),添加元素
s={"Java"}
print(s)
s.add("C")
print(s)
# remove(),删除元素,对象不存在时报错
s.remove("C") # 值为C++时会报错
print(s)
# discard(),删除元素,对象不存在时报错
s.add("C")
s.discard("C") # 值为C++时,会报错keyerror:C++
print(s)
# pop(),删除集合中的任意一个元素
s4={11,22,33,44,55} # 由于前面的报错,后面不能执行,故改正为C
s4.pop()
print(s4)
# clear(),清空集合
s4.clear()
print(s4) # 返回结果为set()
3、关系测试常见操作
# difference(),差集
s1={1,2,3}
s2={1,2}
print(s1-s2)
print("flag1%s"%s1.difference(s2)) # 返回差集
print("flag2%s"%s2.difference(s1)) # 返回空集
# issubset(),是否子集判断
print(s1.issubset(s2))
print(s2.issubset(s1))
# issuperset(),是否父集判断
print(s1.issuperset(s2))
print(s2.issuperset(s1))
# isdisjoint(),是否存在交集
print(s1.isdisjoint(s2))
# symmetric_difference(),对称式差集
s3={1,2,3}
s4={2,3,4}
print(s3.symmetric_difference(s4)) # 即并集-交集
# symmetric_difference_update(),对称式差集,并覆盖更新
print(s3)
print(s3.symmetric_difference_update(s4))
print(s3) # 相当于set1=set1.symmetric_difference_update()
# intersection(),交集
print(s3.intersection(s4))
# intersection_update(),交集并更新
# union(),并集去重
# update(),更新
s5={"Java"}
s6={"C++"}
s5.update(s6)
print(s5)
# in或not in
print("C++" in s5)
print("C++" not in s5)
# <=,>=
print(s5<=s6)
print(s5>=s6)
4、关系测试运符
# & = intersection(),交集
# - = difference(),差集
# | = union(),并集
# ^ = sysmmetric_difference(),对称差集
# <= = issubset(),子集比较