set有两个相似的内置函数:
- difference()返回多个集合的差集
- symmetric_difference()返回两个集合中不重复的元素集合
什么意思呢?被困惑了一下,各种try, try, try…
终于,明白了。
看例子吧!
# 定义三个set
a = set('abcd')
b = set('cdef')
c = set('bcde')
# difference() vs. symmetric_difference()
>>>a.difference(b)
{'a', 'b'}
>>>b.difference(a)
{'e', 'f'}
>>>a.symmetric_difference(b)
{'a', 'e', 'f', 'b'}
>>>b.symmetric_difference(a)
{'a', 'e', 'f', 'b'}
相信看过例子,大家就都明白了。
总结一下
-
difference()返回的新set的元素:包含在a中,并且不包含在集合b中 。
所以a.difference(b) 和b.difference(a)的结果是不一样的。
a.difference(b) 等效于 a - b
b.difference(a) 等效于 b - a -
symmetric_difference(), 此时再体会一下symmetric的含义就清楚了,对称的,所以返回的新set的元素:包含在a中,并且不包含在集合b中 + 包含在b中,并且不包含在集合a中。
这么解释反而复杂了,其实简单来说就是去重。
补充一点
difference()方法的参数可以是一个或多个set。
下面是带多个参数的例子:
# c = set('bcde')
>>>a.difference(b)
{'a', 'b'}
>>>a.difference(b, c)
{'a'}
返回的set中的元素: 包含在a中,并且不包含在集合b和c中