第3章:字典和集合-集合(set、frozenset)

Python 中“集合”有两种,set 和它的不可变的姊妹类型 frozenset ,它们实现也依赖“散列表”,但在它们的散列表里存放的只有元素的引用(就像在字典里只存放键而没有相应的值)。

 集合的本质是许多唯一对象的聚集。因此,集合可以用于去重:

# 集合的本质是许多唯一对象的集合,所以可以用来去重:
s = ['spam', 'spam', 'eggs', 'spam']
ls = set(s)  # 返回一个新集合
print(ls)  # {'spam', 'eggs'}

集合中的元素必须是可散列的,set 类型本身是不可散列的,但是 frozenset 可以。因此有需求的时候可以创建一个包含不同 frozenset 的 set

3.8.1 集合字面量

1. 创建 set 推荐使用字面量的方式,字面量比构造方法性能更快,更易读;:s = {1, 2, 3}
2. 如果创建空 set 只能使用构造方法: s = set()
3. frozenset 只能通过构造方法来创建:fs = frozenset()

3.8.2 集合推导

从示例中还可以看出集合是无序的这个特点:

s = 'Hello Python!'
ls = {i.upper() for i in s}
print(ls)  # {'T', 'O', 'Y', '!', 'L', 'P', ' ', 'H', 'N', 'E'}

3.8.3 集合的操作

表3-2:集合的数学运算:这些方法或者会生成新集合,或者会在条件允许的情况下就地修改集合

数学符号Python运算符方法描述
S ∩ Zs & zs.__and__(z)s 和 z 的交集
z & ss.__rand__(z)反向 & 操作
s.intersection(it, ...)把可迭代的 it 和其他所有参数转化为集合,然后求它们与 s 的交集
s &= zs.__iand__(z)把 s 更新为 s 和 z 的交集
s.intersection_update(it, ...)把可迭代的 it 和其他所有参数转化为集合,然后求得它们与 s 的交集,然后把 s 更新成这个交集
S ∪ Zs | zs.__or__(z)s 和 z 的并集
z | ss.__ror__(z)| 的反向操作
s.union(it, ...)把可迭代的 it 和其他所有参数转化为集合,然后求它们和 s 的并集
s |= zs.__ior__(z)把 s 更新为 s 和 z 的并集
s.update(it, ...)把可迭代的 it 和其他所有参数转化为集合,然后求它们和 s 的并集,并把 s 更新成这个并集
S \ Zs - zs.__sub__(z)s 和 z 的差集,或者叫作相对补集
z - ss.__rsub__(z)- 的反向操作
s.difference(it, ...)把可迭代的 it 和其他所有参数转化为集合,然后求它们和 s 的差集
s -= zs.__isub__(z)把 s 更新为它与 z 的差集
s.difference_update(it, ...)把可迭代的 it 和其他所有参数转化为集合,求它们和 s 的差集,然后把 s 更新成这个差集
s.symmetric_difference(it)求 s 和 set(it) 的对称差集
S △ Zs ^ zs.__xor__(z)求 s 和 z 的对称差集
z ^ ss.__rxor__(z)^ 的反向操作
s.symmetric_difference_update(it, ...)把可迭代的 it 和其他所有参数转化为集合,然后求它们和 s 的对称差集,最后把 s 更新成该结果
s ^= zs.__ixor__(把 s 更新成它与 z 的对称差集

表3-3:集合的比较运算符,返回值是布尔类型

数学符号Python 运算符方法描述
  s.isdisjoint(z)查看 s 和 z 是否不相交(没有共同元素)
e ∈ Se in ss.__contains__(e)元素 e 是否属于 s
S ⊆ Zs <= zs.__le__(z)s 是否为 z 的子集
s.issubset(it)把可迭代的 it 转化为集合,然后查看 s 是否为它的子集
S ⊂ Zs < zs.__lt__(z)s 是否为 z 的真子集
S ⊇ Zs >= zs.__ge__(z)s 是否为 z 的父集
s.issuperset(it)把可迭代的 it 转化为集合,然后查看 s 是否为它的父集
S ⊃ Zs > zs.__gt__(z)s 是否为 z 的真父集

表3-4:集合类型的其他方法

 

set

frozenset

 

s.add(e)

 

把元素 e 添加到 s 中

s.clear()

 

移除掉 s 中的所有元素

s.copy()

对 s 浅复制

s.discard(e)

 

如果 s 里有 e 这个元素的话,把它移除

s.__iter__()

返回 s 的迭代器

s.__len__()

len(s)

s.pop()

 

从 s 中移除一个元素并返回它的值,若 s 为空,则抛出 KeyError 异常

s.remove(e)

 

从 s 中移除 e 元素,若 e 元素不存在,则抛出 KeyError 异常

 

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值