集合
之前看到的列表和字符串都是一种有序序列,而集合是一种无序的序列。
因为集合是无序的,所以当集合中存在两个同样的元素的时候,Python 只会保存其中的一个(唯一性);同时为了确保其中不包含同样的元素,集合中放入的元素只能是不可变的对象(确定性)。
集合生成
可以用 set()
函数来显示的生成空集合:
也可以使用一个列表来初始化一个集合:
集合会自动去除重复元素 1。
集合中的元素是用大括号 {} 包含起来的,这意味着可以用 {} 的形式来创建集合:
创建空集合的时候只能用 set()
函数来创建,因为在 Python 中 {}
创建的是一个空的字典:
集合操作
两个集合的并,返回包含两个集合所有元素的集合(去除重复)。可以用方法 a.union(b)
或者操作 a | b
实现:
两个集合的交,返回包含两个集合共有元素的集合。可以用方法 a.intersection(b)
或者操作 a & b
实现:
a 和 b 的差集,返回只在 a 不在 b 的元素组成的集合。可以用方法 a.difference(b)
或者操作 a - b
实现:
a 和 b 的对称差集,返回在 a 或在 b 中,但是不同时在 a 和 b 中的元素组成的集合。可以用方法 a.symmetric_difference(b)
或者操作 a ^ b
实现(异或操作符):
包含关系
.issubset()
方法或者 b <= a
判断子集:
与之对应,也可以用.issuperset()
方法或者 a >= b
来判断:
操作符可以用来判断真子集:
集合方法
.add()
方法添加单个元素:
如果添加的是已有元素,集合不改变:
.update()
方法更新多个元素:
不可变集合
对应于元组与列表的关系,对于集合,Python 提供了一种叫做不可变集合的数据结构。
不可变集合使用 frozenset () 函数来进行创建:
与集合不同的是,不可变集合一旦创建就不可以改变。
不可变集合的一个主要应用是用来作为字典的键。例如,用一个字典来记录两个城市之间的距离:
由于集合不分顺序,所以不同顺序不会影响查阅结果: