目录
- 1. Python3 中如何查看 set() 的内置方法
- 2. 少废话,上例子
- (1) add()
- (2) 又见清理大师 clear()
- (3) 又见拷贝君 copy()
- (4) 找茬君 difference()
- (5) difference_update()
- (6) discard()
- (7) intersection()
- (8) intersection_update()
- (9) isdisjoint()
- (10) issubset()
- (11) issuperset()
- (12) 又见 pop()
- (13) 又见 remove()
- (14) symmetric_difference()
- (15) symmetric_difference_update()
- (16) union()
- (17) update()
1. Python3 中如何查看 set() 的内置方法
- help(set()) / help(set)
- dir(set()) / dir(set)
2. 少废话,上例子
(1) add()
- 释义:
- 向集合中添加一个元素
- 若元素已经存在,则此操作无效
- 示例:
# 例1.1 向集合内添加元素
s1_1 = {1}
s1_1.add(2)
print(s1_1)
- 运行结果
{1, 2}
# 例1.2
s1_2 = {1}
s1_2.add(3, 4)
- 运行结果
TypeError……add() takes exactly one argument (2 given)
报错原因:add() 只能加一个元素。
想要一次加入多个元素请看 (17) update()。
# 例1.3
s1_3 = {1, 2, 3}
s1_3.add(2)
print(s1_3)
- 运行结果
{1, 2, 3}
加入一个已有的元素不报错。
(2) 又见清理大师 clear()
- 释义:
- 删除集合中所有的元素
- 示例:
# 例2
s2 = {1,2,3,4,5}
print(s2)
print(id(s2))
s2.clear()
print(s2)
print(id(s2))
- 运行结果
{1, 2, 3, 4, 5}
2229866605480
set()
2229866605480
id() 显示 clear() 是原地清空。
列表被清空后仅输出 [],集合被清空后输出 set()。
(3) 又见拷贝君 copy()
- 释义:
- 返回集合的浅拷贝
- 关于深拷贝与浅拷贝,之前挖过坑,编号 Py006-3
- 示例:
# 例3
s3_1 = {1, 2, 3, 4, 5}
s3_2 = s3_1.copy()
print(s3_1)
print(id(s3_1))
print(s3_2)
print(id(s3_2))
- 运行结果
{1, 2, 3, 4, 5}
2229867508456
{1, 2, 3, 4, 5}
2229868024776
(4) 找茬君 difference()
- 释义:
- 将两个或多个集合的差异作为新集合返回
- 所有返回的元素都是基于使用 difference() 的那个集合(不是 difference() 括号中的那个集合)
- 示例:
# 例4
s4_1 = {1, 2, 3}
s4_2 = {0, 1, 2, 3, 4}
s4_3 = {6, 7, 8, 9}
s4_4 = {2}
s4_5 = {3, 4}
print(s4_1.difference(s4_2))
print(s4_1.difference(s4_3))
print(s4_1.difference(s4_4))
print(s4_1.difference(s4_5))
print(s4_1.difference(s4_4, s4_5))
print(s4_1.difference(s4_3, s4_4, s4_5))
- 运行结果
set()
{1, 2, 3}
{1, 3}
{1, 2}
{1}
{1}
从结果看:
- 若 A 是 B 的子集,则 A.difference(B) 输出 set()
- 若 A 与 B 没有交集,则 A.difference(B) 输出 A 本身
- 若 B 是 A 的子集,则 A.difference(B) 输出 A 中与 B 不同的元素,并用大括号括起来
- 若 A 与 B 有交集,又各自有不同的元素,则 A.difference(B) 是将 A 中除去 A 与 B 的交集后的元素输出,并用大括号括起来
- A 可以与 (B1, B2, ……, Bn) 使用 difference(),先求 (B1, B2, ……, Bn) 的并集,再按上面 1~4 运行
- 感觉像是在做概率论中的古典概型
(5) difference_update()
- 释义:
- 从此集合中移除所有与其他集合重复的元素
- 示例:
# 例5
s5_1 = {"YorkFish", "Felicity Smoak", "Dinah Drake"}
s5_2 = {"John Diggle", "Dinah Drake", "Constantine"}
s5_1.difference_update(s5_2)
print(s5_1)
- 运行结果
{'YorkFish', 'Felicity Smoak'}
difference_update() 是更新原集合;
difference() 是返回值。
(6) discard()
- 释义:
- 如果元素是是集合的成员,则将其从集合中移除
- 如果元素不是集合的成员,则不执行任何操作
- 示例:
# 例6
s6 = {1, 2, 3, 4, 5}
s6.discard(1)
print(s6)
s6.discard(6)
print(s6)
- 运行结果
{2, 3, 4, 5}
{2, 3, 4, 5}
(7) intersection()
- 释义:
- 将两个集合的交集作为新集合返回
- 示例:
# 例7
s7_1 = {"YorkFish", "Felicity Smoak", "Dinah Drake"}
s7_2 = {"John Diggle", "Dinah Drake", "Constantine"}
s7_3 = s7_1.intersection(s7_2)
print(s7_3)
- 运行结果
{'Dinah Drake'}
(8) intersection_update()
- 释义:
- 用自身和另一个集合的交集更新集合
- 示例:
# 例8
s8_1 = {"YorkFish", "Felicity Smoak", "Dinah Drake"}
s8_2 = {"John Diggle", "Dinah Drake", "Constantine"}
s8_1.intersection_update(s8_2)
s8_3 = s8_1.intersection_update(s8_2)
print(s8_1)
print(s8_3)
- 运行结果
{'Dinah Drake'}
None
s8_3 接收到的 None 应该是 intersection_update() 返回的。
(9) isdisjoint()
- 释义:
- 如果两个集合的交集为空集,则返回 True;否则,返回 False
- 示例:
# 例9
s9_1 = {"YorkFish", "Felicity Smoak", "Dinah Drake"}
s9_2 = {"John Diggle", "Dinah Drake", "Constantine"}
s9_3 = {"Rorschach", "Comedian", "Nite Owl II"}
print(s9_1.isdisjoint(s9_2))
print(s9_1.isdisjoint(s9_3))
- 运行结果
False
True
(10) issubset()
- 释义:
- 形如 A.issubset(B) 时,如果集合 A 是集合 B 的子集,则返回 True;否则,返回 False
- 示例:
# 例10
s10_1 = {"YorkFish", "Felicity Smoak", "Dinah Drake"}
s10_2 = {"Dinah Drake", "Felicity Smoak"}
s10_3 = {"Rorschach", "Comedian", "Nite Owl II"}
print(s10_2.issubset(s10_1))
print(s10_3.issubset(s10_1))
- 运行结果
True
False
(11) issuperset()
- 释义:
- 与 issubset() 相反
- 形如 A.issuperset(B) 时,如果集合 A 是集合 B 的超集,则返回 True;否则,返回 False
- 示例:
# 例11
s11_1 = {"YorkFish", "Felicity Smoak", "Dinah Drake"}
s11_2 = {"Dinah Drake", "Felicity Smoak"}
s11_3 = {"Rorschach", "Comedian", "Nite Owl II"}
print(s11_1.issuperset(s11_2))
print(s11_1.issuperset(s11_3))
- 运行结果
True
False
(12) 又见 pop()
- 释义:
- 删除并且返回集合中的一个元素
- 如果集合为空,则抛出异常 KeyError (关于异常,挖个坑,日后填平,编号 Py014-1)
- 与列表不同,集合的 pop() 从某种程度上说是随机的
- 示例:
# 例12
s12_1 = {1, 2, 3, 4, 5, 6}
s12_2 = s12_1.pop()
print(s12_2)
print(s12_1)
- 运行结果
1
{2, 3, 4, 5, 6}
(13) 又见 remove()
- 释义:
- 从集合中删除元素;但它必须是该集合的成员
- 如果需要删除的元素不是该集合的成员,则抛出异常 keyError
- 示例:
# 例13.1
s13_1 = {1, 2, 3, 4, 5}
s13_2 = s13_1.remove(1)
print(s13_2)
print(s13_1)
- 运行结果
None
{2, 3, 4, 5}
# 例13.2 接着例13.1
s13_3 = s13_1.remove(2, 3)
print(s13_3)
- 运行结果
TypeError……remove() takes exactly one argument (2 given)
remove() 一次只接收一个参数,给多了不行。
(14) symmetric_difference()
- 释义:
- 将两个集合的“对等差分”作为新集合返回
- 对等差分:不重复部分
- 示例:
# 例14
s14_1 = {"YorkFish", "Felicity Smoak", "Dinah Drake"}
s14_2 = {"John Diggle", "Dinah Drake", "Constantine"}
s14_3 = s14_1.symmetric_difference(s14_2)
print(s14_3)
- 运行结果
{'Felicity Smoak', 'John Diggle', 'Constantine', 'YorkFish'}
(15) symmetric_difference_update()
- 释义:
- 使用自身和另一个集合的“对等差分”更新集合
- 示例:
# 例15
s15_1 = {"YorkFish", "Felicity Smoak", "Dinah Drake"}
s15_2 = {"John Diggle", "Dinah Drake", "Constantine"}
s15_1.symmetric_difference_update(s15_2) # 此处与 symmetric_difference() 有别
print(s15_3)
- 运行结果
{'John Diggle', 'Felicity Smoak', 'Constantine', 'YorkFish'}
symmetric_difference() 是将对等差分返回给一个新的集合;
symmetric_difference_update() 是用对等差分更新原有集合。
(16) union()
- 释义:
- 将集合的并集作为新的集合返回
- 示例:
# 例16
s16_1 = {"YorkFish", "Felicity Smoak", "Dinah Drake"}
s16_2 = {"John Diggle", "Dinah Drake", "Constantine"}
s16_3 = s16_1.union(s16_2)
print(s16_3)
- 运行结果
{'John Diggle', 'YorkFish', 'Dinah Drake', 'Constantine', 'Felicity Smoak'}
(17) update()
- 释义:
- 使用自身和其他集合的并集更新集合
- 示例:
# 例17
s17_1 = {"YorkFish", "Felicity Smoak", "Dinah Drake"}
s17_2 = {"John Diggle", "Dinah Drake", "Constantine"}
s17_1.update(s17_2)
print(s17_1)
- 运行结果
{'Constantine', 'Felicity Smoak', 'John Diggle', 'Dinah Drake', 'YorkFish'}
update() 与 union() 的区别就像 symmetric_difference_update() 与 symmetric_difference() 的区别。
update() 是更新原有的集合;
union() 是将结果返回给一个新的集合。