P28 集合
花括号中,如果是映射关系,那么定义的是字典;如果是元素,那么定义的是集合。 集合中的元素是唯一的。 集合是无序的,因此无法索引index元素
创建集合 set1 = set() 列表转集合: s2 = set(list),此时如果列表中有重复元素,在集合中会被过滤。 快速列表去重:l2 = list(set(list1)) l2的元素顺序与list1 不一致
访问集合值 ①for i in set() ②if 元素 in set()
添加元素 set.add(元素)
删除元素 set.remove(元素)
不可变集合
fs = frozenset()
不能使用添加、删除操作,但是可以像set()一样进行读取、转换为list等。
课后题
-
请问集合的唯一作用是什么呢? 对元素去重
-
如果你希望创建的集合是不变的,应该怎么做? set1 = frozenset()
-
请问如何确定一个集合里边有多少个元素? len(set1)
-
请目测以下代码会打印什么内容? num_set = set([1, 2, 3, 4, 5]) num_set[0]
会报错,集合无法索引
- 请问 set1 = {[1, 2]} 和 set2 = set([1, 2]) 执行的结果一样吗?
set1 = {[1,2]} set2 = {1,2}
不一样
- 打开你的IDLE,输入set1 = {1, 1.0},你发现了什么?
浮点数和整数相等时,被合并了
- 请问如何给集合添加和删除元素? set1.add(元素) set1.remove(元素)
动动手:
- 自学扩展:自己花点时间看下这个表格(bbs.fishc.com/thread-4527…
| 集合(s).方法名 | 等价符号 | 方法说明 | |
|---|---|---|---|
| s.issubset(t) | s <= t | 子集测试(允许不严格意义上的子集):s 中所有的元素都是 t 的成员 | |
| s < t | 子集测试(严格意义上):s != t 而且 s 中所有的元素都是 t 的成员 | ||
| s.issuperset(t) | s >= t | 超集测试(允许不严格意义上的超集):t 中所有的元素都是 s 的成员 | |
| s > t | 超集测试(严格意义上):s != t 而且 t 中所有的元素都是 s 的成员 | ||
| s.union(t) | s | t | 合并操作:s "或" t 中的元素 |
| s.intersection(t) | s & t | 交集操作:s "与" t 中的元素 | |
| s.difference | s - t | 差分操作:在 s 中存在,在 t 中不存在的元素 | |
| s.symmetric_difference(t) | s ^ t | 对称差分操作:s "或" t 中的元素,但不是 s 和 t 共有的元素 | |
| s.copy() | 返回 s 的拷贝(浅复制) | ||
| 以下方法仅适用于可变集合 | |||
| s.update | s | = t | 将 t 中的元素添加到 s 中 |
| s.intersection_update(t) | s &= t | 交集修改操作:s 中仅包括 s 和 t 中共有的成员 | |
| s.difference_update(t) | s -= t | 差修改操作:s 中包括仅属于 s 但不属于 t 的成员 | |
| s.symmetric_difference_update(t) | s ^= t | 对称差分修改操作:s 中包括仅属于 s 或仅属于 t 的成员 | |
| s.add(obj) | 加操作:将 obj 添加到 s | ||
| s.remove(obj) | 删除操作:将 obj 从 s 中删除,如果 s 中不存在 obj,将引发异常 | ||
| s.discard(obj) | 丢弃操作:将 obj 从 s 中删除,如果 s 中不存在 obj,也没事儿^_^ | ||
| s.pop() | 弹出操作:移除并返回 s 中的任意一个元素 | ||
| s.clear() | 清除操作:清除 s 中的所有元素 |