1.Python汇合
汇合(set)是一个无序的不反复元素序列。
能够应用大括号 { } 或者 set() 函数创立汇合,留神:创立一个空集合必须用 set() 而不是 { },因为 { } 是用来创立一个空字典。
创立格局:
parame = {value01,value02,...} 或者 set(value)
如下为示例代码(代码能够在在线python3环境中运行):
>>> company = {'Baidu', '搞代码python', 'google', 'ByteDance', '搞代码python', 'Taobao', 'Tencent'} >>> print(company) # 这里演示的是去重性能 {'Baidu', '搞代码python', 'google', 'ByteDance', 'Taobao', 'Tencent'} >>> 'Baidu' in basket # 疾速判断元素是否在汇合内 True >>> 'Meituan' in basket False
>>> # 上面展现两个汇合间的运算. ... >>> a = set('abracadabra') >>> b = set('alacazam') >>> a {'a', 'r', 'b', 'c', 'd'} >>> a - b # 汇合a中蕴含而汇合b中不蕴含的元素 {'r', 'd', 'b'} >>> a | b # 汇合a或b中蕴含的所有元素 {'a', 'c', 'r', 'd', 'b', 'm', 'z', 'l'} >>> a & b # 汇合a和b中都蕴含了的元素 {'a', 'c'} >>> a ^ b # 不同时蕴含于a和b的元素 {'r', 'd', 'b', 'm', 'z', 'l'}
相似列表推导式,同样汇合反对汇合推导式(Set comprehension):
>>> a = {x for x in 'abracadabra' if x not in 'abc'} >>> a {'r', 'd'}
2.汇合的基本操作
(1)增加元素
语法格局如下:
s.add( x )
将元素 x 增加到汇合 s 中,如果元素已存在,则不进行任何操作。
>>> company = set(("Google", "搞代码python", "Taobao")) >>> company.add("Facebook") >>> print(company) {'Taobao', 'Facebook', 'Google', '搞代码python'}
还有一个办法,也能够增加元素,且参数能够是列表,元组,字典等,语法格局如下:
s.update( x )
x 能够有多个,用逗号离开。如下为示例代码(代码能够在在线python3环境中运行):
>>> company = set(("Google", "搞代码python", "Taobao")) >>> company.update({"Facebook", "LinkedIn"}) >>> print(company) {'LinkedIn', 'Google', '搞代码python', 'Facebook', 'Taobao'} >>> company.update([1,4],[5,6]) >>> print(company) {1, 3, 4, 5, 6, 'Google', 'Taobao', 'Runoob'}
(2)移除元素
语法格局如下:
s.remove( x )
将元素 x 从汇合 s 中移除,如果元素不存在,则会产生谬误。如下为示例代码(代码能够在在线python3环境中运行):
>>> company = set(("Google", "搞代码python", "Taobao")) >>> company.remove("Taobao") >>> print(company) {'Google', '搞代码python'} >>> company.remove("Facebook") # 不存在会产生谬误 Traceback (most recent call last): File "<stdin>", line 1, in <module> KeyError: 'Facebook'
此外还有一个办法也是移除汇合中的元素,且如果元素不存在,不会产生谬误。格局如下所示:
s.discard( x )
>>> company = set(("Google", "搞代码python", "Taobao")) >>> company.discard("Facebook") # 不存在不会产生谬误 >>> print(company) {'Taobao', 'Google', '搞代码python'}
咱们也能够设置随机删除汇合中的一个元素,语法格局如下:
s.pop()
company = set(("Google", "搞代码python", "Taobao", "Facebook")) x = company.pop() print(x)
输入后果:
搞代码python
屡次执行测试后果都不一样。
set 汇合的 pop 办法会对汇合进行无序的排列,而后将这个无序排列汇合的右面第一个元素进行删除。
(3)计算汇合元素个数
语法格局如下:
len(s)
计算汇合 s 元素个数。
company = set(("Google", "搞代码python", "Taobao", "Facebook")) print(len(company))
(4)清空集合
语法格局如下:
s.clear()
清空集合 s。
company = set(("Google", "搞代码python", "Taobao", "Facebook")) company.clear()
(5)判断元素是否在汇合中存在
语法格局如下:
x in s
判断元素 x 是否在汇合 s 中,存在返回 True,不存在返回 False。
company = set(("Google", "搞代码python", "Taobao", "Facebook")) "Facebook" in company
(6)汇合内置办法残缺列表
办法 | 形容 |
---|---|
add() | 为汇合增加元素 |
clear() | 移除汇合中的所有元素 |
copy() | 拷贝一个汇合 |
difference() | 返回多个汇合的差集 |
difference_update() | 移除汇合中的元素,该元素在指定的汇合也存在。 |
discard() | 删除汇合中指定的元素 |
intersection() | 返回汇合的交加 |
intersection_update() | 返回汇合的交加。 |
isdisjoint() | 判断两个汇合是否蕴含雷同的元素,如果没有返回 True,否则返回 False。 |
issubset() | 判断指定汇合是否为该办法参数汇合的子集。 |
issuperset() | 判断该办法的参数汇合是否为指定汇合的子集 |
pop() | 随机移除元素 |
remove() | 移除指定元素 |
symmetric_difference() | 返回两个汇合中不反复的元素汇合。 |
symmetric_difference_update() | 移除以后汇合中在另外一个指定汇合雷同的元素,并将另外一个指定汇合中不同的元素插入到以后汇合中。 |
union() | 返回两个汇合的并集 |
update() | 给汇合增加元素 |
3.视频教程
请点击到B站查看【双语字幕】版本
https://www.bilibili.com/vide…
材料与代码下载
本教程系列的代码能够在搞代码python对应的github中下载,可本地python环境运行,能迷信上网的宝宝也能够间接借助google colab一键运行与交互操作学习哦!
本教程系列波及的Python速查表能够在以下地址下载获取:
- Python速查表
拓展参考资料
- Python教程—Python3文档
- Python教程-廖雪峰的官方网站
搞代码python相干文章举荐
- python介绍
- python装置与环境配置
- python根底语法
- python根底数据类型
- python运算符
- python条件管制与if语句
- python循环语句
- python while循环
- python for循环
- python break语句
- python continue语句
- python pass语句
- python字符串及操作
- python列表
- python元组
- python字典
- python汇合
- python函数
- python迭代器与生成器
- python数据结构
- python模块
- python文件读写
- python文件与目录操作
- python谬误与异样解决
- python面向对象编程
- python命名空间与作用域
- python工夫和日期
搞代码python系列教程举荐
- 图解Python编程:从入门到精通系列教程
- 图解数据分析:从入门到精通系列教程
- 图解AI数学根底:从入门到精通系列教程
- 图解大数据技术:从入门到精通系列教程