集合类型
python集合是什么?无序组合元素不可重复set() 函数集合类型的操作符集合类型操作符差集S - T or S.difference(T)S -= T or S.difference_update(T)
交集S&T or S.intersection(T)S&=T or S.intersection_update(T)
并集S|T or S.union(T)S|=T or S.updat(T)
补集S^T or S.symmetric_difference(T)S^=T or S.symmetric_difference_update(T)
S和T数组比较S<=T or S.issubset(T)S>=T or S.issuperset(T)
集合类型的操作函数或方法S.add(X)S.clear()S.copy()S.pop()S.discard(X) or S.remove(X)S.isdisjoint(T)X in S or X not in S
优势
冰冻的集合frozenset()没有add()、remove()、clear()、pop()等函数
白话学python,就找三岁学编程,用最简谱的话带你从0开始
python集合是什么?
python中也有集合类型(set) 该集合类型与数学的集合基本相似。 概念:包含0个或多个数据项的无序组合。集合元素不可重复。 集合中只包含整数、浮点型、字符串、元组等不可变数据。
无序组合
由于集合的无序性所以没有索引和切片的概念 不能够切片
可以动态添加或删除元素。
元素不可重复
集合里面的元素是单独的唯一的,不可以重复的 使用集合可以把其他数据类型的内容过滤重复元素
set() 函数
set()函数把其他类型的转换成集合。
————————————————————————————
#集合的创建及无序性
>>> s = {123, 'python', (13, 14), 5.18}
>>> s
{(13, 14), 123, 5.18, 'python'}
>>> t = {123, 'python', (13, 14), 5.18, 'hallo'}
>>> t
{5.18, 'python', (13, 14), 'hallo', 123}
#set() 函数的使用
>>> w = set('python')
>>> w
{'n', 'y', 'h', 'p', 't', 'o'}
>>> v = set(((13, 14), 123, 5.18, 'python'))
>>> v
{(13, 14), 123, 5.18, 'python'}
#不可重复性
>>> c = {3, 5, 6, 3}
>>> c
{3, 5, 6}
>>> a = 3, 6, 9, 6 #创建元组a
>>> a = set(a)# 将元组转换成列表
>>> a
{9, 3, 6}
集合类型的操作符
集合共有4种基本操作:
交集 (&)
并集 (|)
差集 (-)
补集 (^)
集合类型操作符
操作符描述S-T or S.difference(T)返回一个新的集合,包括在集合S但是不包括在T中的元素S -= T or S.difference_update(T)更新集合S ,返回S中有的但是T中没有的元素S&T or S.intersection(T)返回一个新集合,包括在S和T中的相同的元素S&=T or S.intersection_update(T)更新集合S,返回集合S和T中共有的元素S|T or S.union(T)返回一个新的集合,包括S和T中所有的元素S|=T or S.updat(T)更新集合S,返回 S 和 T 的所有元素S^T or S.symmetric_difference(T)返回一个新集合,包含 S 和T 之中所有不同的元素S^=T or S.symmetric_difference_update(T)更新集合 S ,返回集合 S 和 T 集合的不相同值S<=T or S.issubset(T)S 与 T相同,或是其子集则返回 True 否则返回 False,用 S=T or S.issuperset(T)与上面的相反,S 与 T 相同或 S 是 T 的子集,返回 True ,否者返回 False,用 S>T 来判断 S 是不是 T 的 真超集
差集
集合A和B的差集就是两者的差
S - T or S.difference(T)
返回一个新的集合,包括在集合S但是不包括在T中的元素
>>> s - t
set()
>>> t-s
{'hallo'}
>>> s.difference(t)
set()
>>> t.difference(s)
{'hallo'}
S -= T or S.difference_update(T)
更新集合S ,返回S中有的但是T中没有的元素
>>> s -= t
>>> s
set()
>>> s = {123, 'python', (13, 14), 5.18}
>>> t = {123, 'python', (13, 14), 5.18, 'hallo'}
>>> t -= s
>>> t
{'hallo'}
>>> s = {123, 'python', (13, 14), 5.18}
>>> t = {123, 'python', (13, 14), 5.18, 'hallo'}
>>> t.difference_update(s)
>>> t
{'hallo'}
>>> s = {123, 'python', (13, 14), 5.18}
>>> t = {123, 'python', (13, 14), 5.18, 'hallo'}
>>> s.difference_update(t)
>>> s
set()
交集
A和B相同的部分
S&T or S.intersection(T)
返回一个新集合,包括在S和T中的相同的元素
>>> s = {123, 'python', (13, 14), 5.18}
>>> t = {123, 'python', (13, 14), 5.18, 'hallo'}
>>> s & t
{(13, 14), 123, 5.18, 'python'}
>>> t & s
{(13, 14), 123, 5.18, 'python'}
>>> s.intersection(t)
{(13, 14), 123, 5.18, 'python'}
>>> t.intersection(s)
{(13, 14), 123, 5.18, 'python'}
这里s和t的顺序无关,结果都一样
S&=T or S.intersection_update(T)
更新集合S,返回集合S和T中共有的元素
>>> s &= t
>>> s
{(13, 14), 123, 5.18, 'python'}
>>> t &= s
>>> t
{(13, 14), 123, 5.18, 'python'}
>>> s.intersection_update(t)
>>> s
{(13, 14), 123, 5.18, 'python'}
>>> t.intersection_update(s)
>>> t
{(13, 14), 123, 5.18, 'python'}
这里要注意s和t的位置,结果是不一样的
并集
A和B的并集是A和B里面所有的元素
S|T or S.union(T)
返回一个新的集合,包括S和T中所有的元素
>>> s = {(13, 14), 123, 5.18, 'python'}
>>> t = {5.18, 'python', (13, 14), 'hallo', 123}
>>> s | t
{5.18, 'python', (13, 14), 'hallo', 123}
>>> s.union(t)
{5.18, 'python', (13, 14), 'hallo', 123}
因为不改变原有代码,s和 t 的顺序不会产生影响
S|=T or S.updat(T)
更新集合S,返回 S 和 T 的所有元素
>>> s |= t
>>> s
{5.18, 'python', (13, 14), 'hallo', 123}
>>> t |= s
>>> t
{5.18, 'python', (13, 14), 'hallo', 123}
>>> s = {(13, 14), 123, 5.18, 'python'}
>>> t.update(s)
>>> t
{5.18, 'python', (13, 14), 'hallo', 123}
>>> s.update(t)
>>> s
{5.18, 'python', (13, 14), 'hallo', 123}
因为会更新原有集合,所以注意顺序
补集
A 和 B 集合中不相同的元素
S^T or S.symmetric_difference(T)
返回一个新集合,包含 S 和T 之中所有不同的元素
>>> s = {(13, 14), 123, 5.18, 'python'}
>>> s ^ t
{'hallo'}
>>> s.symmetric_difference(t)
{'hallo'}
返回新集合,s 和 t 的位置无关
S^=T or S.symmetric_difference_update(T)
更新集合 S ,返回集合 S 和 T 集合的不相同值
>>> s ^= t
{'hallo'}
>>> t ^= s
{5.18, 'python', (13, 14), 123}
>>>s.symmetric_difference_update(t)
>>> s
{'hallo'}
>>> t.symmetric_difference_update(s)
>>> t
{'hallo'}
更新了数组,注意顺序和位置
S和T数组比较
S<=T or S.issubset(T)
S 与 T相同,或是其子集则返回 True 否则返回 False 用 S
>>> s = {(13, 14), 123, 5.18, 'python'}
>>> t={5.18, 'python', (13, 14), 'hallo', 123}
>>> s <= t
True
>>> s.issubset (t)
True
>>> t <= s
False
>>> t.issubset(s)
False
S>=T or S.issuperset(T)
与上面的相反,S 与 T 相同或 S 是 T 的子集,返回 True ,否者返回 False 用 S>T 来判断 S 是不是 T 的 真超集
>>> s >= t
False
>>> s.issuperset(t)
False
>>> t >= s
True
>>> t.issuperset(s)
True
集合类型的操作函数或方法
操作函数及方法描 述/解 释S.add(X)如果 元素 X 不在 S 集合中则添加到集合 SS.clear()移除 S 中的所有数据项S.copy()返回一个集合的副本S.pop()随机返回集合的一个元素,若S为空则报错!S.discard(X)如果元素 X 在集合 S 中,则删除,不在也不报错S.remove(X)如果元素 X 在集合 S 中,则删除,不在则报错(keyError异常)S.isdisjoint(T)若 S 和 T 没有相同的元素则返回TrueX in S如果X 是S的元素返回 True 否则返回FalseX not in S如果X 不是S的元素返回 True 否则返回False
S.add(X)
如果 元素 X 不在 S 集合中则添加到集合 S
>>> s.add(250)
>>> s
{5.18, 'python', (13, 14), 250, 123}
S.clear()
移除 S 中的所有数据项
>>> s = {5.18, 'python', (13, 14), 250, 123}
>>> s.clear()
>>> s
set()
注:移除数据项,不是删除整个集合
S.copy()
返回一个集合的副本 注:这里是副本,不是返回集合
>>> s.copy()
{(13, 14), 123, 5.18, 'python'}
S.pop()
随机返回集合的一个元素,若S为空则报错!
>>> s.pop()
(13, 14)
>>> s.pop()
123
#报错测试
>>> b = set()
>>> b.pop()
Traceback (most recent call last):
File "", line 1, in
b.pop()
KeyError: 'pop from an empty set'
S.discard(X) or S.remove(X)
S.discard(X) | 如果元素 X 在集合 S 中,则删除,不在也不报错 S.remove(X) | 如果元素 X 在集合 S 中,则删除,不在则报错(keyError异常)
# S.discard(X)
>>> s = {5.18, 'python', (13, 14), 250, 123}
>>> s.discard(123)
>>> s
{5.18, 'python', (13, 14), 250}
>>> s.discard(6)
>>> s
{5.18, 'python', (13, 14), 250}
#S.remove(X)
>>> s = {5.18, 'python', (13, 14), 250, 123}
>>> s.remove(123)
>>> s
{5.18, 'python', (13, 14), 250}
>>> s.remove(12)
Traceback (most recent call last):
File "", line 1, in
s.remove(12)
KeyError: 12
S.isdisjoint(T)
若 S 和 T 没有相同的元素则返回True
>>> s.isdisjoint(t)
False
X in S or X not in S
X in S | 如果X 是S的元素返回 True 否则返回False X not in S | 如果X 不是S的元素返回 True 否则返回False
>>> 'python' in s
True
>>> 'python' not in s
False
>>> 'hallo' in s
False
>>> 'hallo' not in s
True
优势
集合的单一性,不包括重复的元素是特色 所以有需要数据去重的可以用集合来完成
冰冻的集合
冰冻的被冻住了那么久无法修改了,这是一个特殊的集合又叫不可变集合
frozenset()
定义冰冻的集合(不可变集合)
>>> a = frozenset('pythopn')
>>> a
frozenset({'y', 'p', 'h', 't', 'n', 'o'})
既然是不可变的集合那么上面的 添加、删除就不存在了
没有add()、remove()、clear()、pop()等函数
>>> a.add('c') #add()报错
Traceback (most recent call last):
File "", line 1, in
a.add('c')
AttributeError: 'frozenset' object has no attribute 'add'
>>> a.clear('h')#clear() 报错
Traceback (most recent call last):
File "", line 1, in
a.clear('h')
AttributeError: 'frozenset' object has no attribute 'clear'
>>> a.remove('h')#remove()报错
Traceback (most recent call last):
File "", line 1, in
a.remove('h')
AttributeError: 'frozenset' object has no attribute 'remove'
>>> a.pop()# pop()报错
Traceback (most recent call last):
File "", line 1, in
a.pop()
AttributeError: 'frozenset' object has no attribute 'pop'
>>> a.discard('h')#discard()报错
Traceback (most recent call last):
File "", line 1, in
a.discard('h')
AttributeError: 'frozenset' object has no attribute 'discard'
以上函数均不适用于冰冻集合,估计是他太高冷,没有那么平易近人。 他有哈希值,可以作为字典的键,也可以作为元素,就是不能够修改,比较硬核。