实例讲解Python集合类型的常用内置方法

47 篇文章 0 订阅
47 篇文章 1 订阅

集合是Python中的一种内置类型,用来表示不重复的一组数据。今天给大家讲讲集合的内置函数方法。

1. set.add()和set1.update(set2)

  • set.add()给集合添加元素,如果添加的元素在集合中已存在,则不执行任何操作。

  • set1.update(set2)添加新的元素或集合到当前集合中,如果添加的元素在集合中已存在,则该元素只会出现一次,重复的会忽略。

x = {"apple", "banana", "cherry"}
y = {"google", "runoob", "apple"}
 
x.update(y) 
print(x)
# 输出:
{'runoob', 'cherry', 'banana', 'google', 'apple'}

2. set.clear()、set.discard()、set.pop()、set.remove()

  • set.clear()移除集合中的所有元素。

  • set.discard()移除指定的集合元素。在移除一个不存在的元素时「不会发生错误」

  • set.remove()移除指定的集合元素。在移除一个不存在的元素时「会发生错误」

  • set.pop()「随机」移除一个元素。

3. set.copy()

拷贝一个集合。

4. set1.difference(set2)和set1.difference_update(set2)

计算集合的「差集」,即:集合元素包含在 set1 中,但不包含在 set2 中。

  • difference() 返回一个移除相同元素的新集合。

  • difference_update() 直接在原来的集合中移除元素,没有返回值。

x = {"apple", "banana", "cherry"}
y = {"google", "microsoft", "apple"}
x.difference(y) 
# 输出:
{'banana', 'cherry'}
x = {"apple", "banana", "cherry"}
y = {"google", "microsoft", "apple"}
 
x.difference_update(y) 
print(x)
# 输出:
{'banana', 'cherry'}

5. set0.intersection(set1, set2 ... etc)和set0.intersection_update(set1, set2 ... etc)

计算两个或更多集合中都包含的元素,即「交集」

  • intersection() 返回一个新的集合。

  • intersection_update() 在原始的集合上移除不重叠的元素。

x = {"a", "b", "c"}
y = {"c", "d", "e"}
z = {"f", "g", "c"}

x.intersection(y, z)
# 输出:
{'c'}
x = {"a", "b", "c"}
y = {"c", "d", "e"}
z = {"f", "g", "c"}
 
x.intersection_update(y, z) 
print(x)
# 输出:
{'c'}

6. set1.isdisjoint(set2)

判断两个集合是否包含「相同的元素」,如果没有返回 True,否则返回 False。

x = {"apple", "banana", "cherry"}
y = {"google", "runoob", "facebook"}

x.isdisjoint(y) 
# 输出:
True

7. set1.issubset(set2)

判断 「set1」 的所有元素是否都包含在指定 「set2」 中,如果是则返回 True,否则返回 False。

x = {"a", "b", "c"}
y = {"f", "e", "d", "c", "b", "a"}

x.issubset(y)
# 输出:
True

8. set1.issuperset(set2)

判断 「set2」 的所有元素是否都包含在指定 「set1」 中,如果是则返回 True,否则返回 False。

x = {"f", "e", "d", "c", "b", "a"}
y = {"a", "b", "c"}
 
x.issuperset(y) 
# 输出:
True

9. set1.symmetric_difference(set2)和 set1.symmetric_difference_update(set2)

计算两个集合中不重复的元素集合,即会移除两个集合中都存在的元素。

  • set1.symmetric_difference(set2)返回新集合。

  • set1.symmetric_difference_update(set2)移除当前集合中在另外一个指定集合相同的元素,并将另外一个指定集合中不同的元素插入到当前集合中。

x = {"apple", "banana", "cherry"}
y = {"google", "runoob", "apple"}
 
x.symmetric_difference(y) 
# 输出:
{'banana', 'cherry', 'google', 'runoob'}
x = {"apple", "banana", "cherry"}
y = {"google", "runoob", "apple"}
 
x.symmetric_difference_update(y) 
print(x)
# 输出:
{'google', 'runoob', 'banana', 'cherry'}

10. set0.union(set1, set2...)

返回两个或多个集合的「并集」,即包含了所有集合的元素,重复的元素只会出现一次。

x = {"a", "b", "c"}
y = {"f", "d", "a"}
z = {"c", "d", "e"}

x.union(y, z) 
{'a', 'b', 'c', 'd', 'e', 'f'}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值