集合set-深入学习
集合set,无序,是不允许重复内容的,也就是不允许重复元素,如果有重复,会自动忽略,可接收可迭代类型 (一般用于需要判断和处理交集时候用到)
集合与字典的区别是,集合没有键只有值,字典是有键的字典是一对键值对
所以创建空集合不能用{}大括号,用大括号创建空集合默认会变成字典,如果需要创建空集合用set()
创建集合
1 #!/usr/bin/env python
2 # -*- coding:utf-8 -*-
3 #创建集合
4 a = set()
5 a = {11,22,33,44,55,55}
6 print(a)
7 #打印出 {33, 11, 44, 22, 55}
集合的类库功能
add(
self
,
*
args,
*
*
kwargs)
"添加元素"(要添加的元素)
clear(
self
,
*
args,
*
*
kwargs)
1 #!/usr/bin/env python
2 # -*- coding:utf-8 -*-
3 #创建一个集合
4 se = {11,22,33,44}
5 #向集合里添加元素
6 se.add(55)
7 print(se)
8 #打印出 {33, 11, 44, 22, 55}
"清空元素"()
1 #!/usr/bin/env python
2 # -*- coding:utf-8 -*-
3 #创建一个集合
4 se = {11,22,33,44}
5 #清空集合里的元素
6 se.clear()
7 print(se)
8 #打印出 空集合
difference(
self
,
*
args,
*
*
kwargs)
"查找出一个集合里存在,另外一个集合不存在的元素"(格式:查找集合.difference(被判断的集合)
)
1 #!/usr/bin/env python
2 # -*- coding:utf-8 -*-
3 #创建二个集合
4 a = {11,22,33,44}
5 b = {11,55,88,44}
6 #查找出a集合里存在,b集合不存在的元素
7 c = a.difference(b)
8 print(c)
9 #打印出 {33, 22}
difference_update(
self
,
*
args,
*
*
kwargs)
"从当前集合中删除和B中相同的元素"(b集合)
1 #!/usr/bin/env python
2 # -*- coding:utf-8 -*-
3 #创建二个集合
4 a = {11,22,33,44,999}
5 b = {11,55,88,44}
6 #从a集合中删除和b集合中相同的元素
7 a.difference_update(b)
8 print(a)
9 #打印出 {33, 22, 999}
discard(
self
,
*
args,
*
*
kwargs)
"移除指定元素,不存在不报错"(要移除的元素)
1 #!/usr/bin/env python
2 # -*- coding:utf-8 -*-
3 #创建一个集合
4 a = {11,22,33,44,999}
5 #移除指定元素,不存在不报错
6 a.discard(999)
7 print(a)
8 #打印出 {33, 11, 44, 22}
intersection(
self
,
*
args,
*
*
kwargs)
"交集,查找出a集合和b集合都存在的元素"(b集合)
1 #!/usr/bin/env python
2 # -*- coding:utf-8 -*-
3 #创建二个集合
4 a = {66,22,33,44,99}
5 b = {44,55,66,77,33}
6 #交集,查找出a集合和b集合都存在的元素
7 c = a.intersection(b)
8 print(c)
9 #打印出 {33, 66, 44}
intersection_update(
self
,
*
args,
*
*
kwargs)
"交集,查找出a集合和b集合都存在的元素,并重新更新到a集合"(b集合)
1 #!/usr/bin/env python
2 # -*- coding:utf-8 -*-
3 #创建二个集合
4 a = {66,22,33,44,99}
5 b = {44,55,66,77,33}
6 #交集,查找出a集合和b集合都存在的元素,并重新更新到a集合
7 a.intersection_update(b)
8 print(a)
9 #打印出 {33, 66, 44}
isdisjoint(
self
,
*
args,
*
*
kwargs)
"检查a集合和b集合是否有都存在的元素"(b集合)
返回布尔值:如果没有都存在的,返回True,否则返回False
1 #!/usr/bin/env python
2 # -*- coding:utf-8 -*-
3 #创建二个集合
4 a = {66,22,33,44,99}
5 b = {44,55,66,77,33}
6 #检查a集合和b集合是否有都存在的元素,
7 c = a.isdisjoint(b)
8 print(c)
9 #打印出 False 说明有交集
issubset(
self
,
*
args,
*
*
kwargs)
"判断一个集合是否是另一个集合的子序列"(b集合)
是返回True 不是返回False
1 #!/usr/bin/env python
2 # -*- coding:utf-8 -*-
3 #创建二个集合
4 a = {11,22,33,44}
5 b = {11,22}
6 #检查a集合是否是b集合的子序列,
7 c1 = a.issubset(b)
8 print(c1)
9 #检查b集合是否是a集合的子序列
10 c2 = b.issubset(a)
11 print(c2)
12 #打印出
13 #False 检查a集合是否是b集合的子序列,说明a集合不是b集合的子序列
14 #True 检查b集合是否是a集合的子序列,说明b集合是a集合的子序列
issuperset(
self
,
*
args,
*
*
kwargs)
"判断一个集合是否是另一个集合的父序列"(b集合)
是返回True 不是返回False
1 #!/usr/bin/env python
2 # -*- coding:utf-8 -*-
3 #创建二个集合
4 a = {11,22,33,44}
5 b = {11,22}
6 #检查a集合是否是b集合的父序列,
7 c1 = a.issuperset(b)
8 print(c1)
9 #检查b集合是否是a集合的父序列
10 c2 = b.issuperset(a)
11 print(c2)
12 #打印出
13 #True 检查a集合是否是b集合的父序列,说明a集合是b集合的父序列
14 #False 检查b集合是否是a集合的父序列,说明b集合不是a集合的父序列
pop(
self
,
*
args,
*
*
kwargs)
"移除元素"()
一般默认移除第一个元素,只是集合有一套自己的元素排序规则,
1 #!/usr/bin/env python
2 # -*- coding:utf-8 -*-
3 a = {44,55,66,77,88}
4 #打印出集合,可以看到集合里的元素排序情况
5 print(a)
6 #移除集合里的元素,默认移除元素里的第一个排序元素
7 b = a.pop()
8 #打印出被移除的元素
9 print(b)
10 #打印出a集合被移除后剩下的所有元素
11 print(a)
12 #最后打印出
13 #{88, 66, 44, 77, 55}
14 #
15 #{66, 44, 77, 55}
remove(
self
,
*
args,
*
*
kwargs)
"移除指定元素,不存在保错"(要移除的元素)
1 #!/usr/bin/env python
2 # -*- coding:utf-8 -*-
3 a = {44,55,66,77,88}
4 #打印出a集合
5 print(a)
6 #移除a集合里指定的元素
7 a.remove(44)
8 #打印a集合移除指定元素后,剩下的所有元素
9 print(a)
10 #最后输出
11 #{88, 66, 44, 77, 55}
12 #{88, 66, 77, 55}
复制代码
symmetric_difference(
self
,
*
args,
*
*
kwargs)
"对称差集,就是将两个集合里没有交集的元素重新组合成一个新的集合"(b集合)
1 #!/usr/bin/env python
2 # -*- coding:utf-8 -*-
3 a = {44,55,66,77,88}
4 b = {44,55,11,22,33}
5 #对称差集,就是将两个集合里没有交集的元素重新组合成一个新的集合
6 c = a.symmetric_difference(b)
7 print(c)
8 #输出
9 #{33, 66, 11, 77, 22, 88}
symmetric_difference_update(
self
,
*
args,
*
*
kwargs)
"对称差集,并更新到a中,就是将两个集合里没有交集的元素重新组合更新给a集合"(b集合)
1 #!/usr/bin/env python
2 # -*- coding:utf-8 -*-
3 a = {44,55,66,77,88}
4 b = {44,55,11,22,33}
5 #对称差集,并更新到a中,就是将两个集合里没有交集的元素重新组合更新给a集合
6 a.symmetric_difference_update(b)
7 print(a)
8 #输出
9 #{33, 66, 11, 77, 22, 88}
复制代码
union(
self
,
*
args,
*
*
kwargs)
"并集,将两个集合合并成一个新的集合,元素有重复的会自动忽略"(b集合)
1 #!/usr/bin/env python
2 # -*- coding:utf-8 -*-
3 a = {44,55,66,77,88}
4 b = {44,55,11,22,33}
5 #并集,将两个集合合并成一个新的集合,元素有重复的会自动忽略只保留一次
6 c = a.union(b)
7 print(c)
8 #输出
9 #{33, 66, 11, 44, 77, 22, 55, 88}
update(
self
,
*
args,
*
*
kwargs)
"更新,将b集合更新到a集合,相当于合并"(b集合)
1 #!/usr/bin/env python
2 # -*- coding:utf-8 -*-
3 a = {44,55,66,77,88}
4 b = {44,55,11,22,33}
5 #更新,将b集合更新到a集合,相当于合并
6 a.update(b)
7 print(a)
8 #输出
9 #{33, 66, 11, 44, 77, 22, 55, 88}
集合set-深入学习的更多相关文章
- Java集合源码学习(五)几种常用集合类的比较
这篇笔记对几个常用的集合实现,从效率,线程安全和应用场景进行综合比较. >>ArrayList.LinkedList与Vector的对比 (1)相同和不同都实现了List接口,使用类似.V ...
- Java集合源码学习(三)LinkedList分析
前面学习了ArrayList的源码,数组是顺序存储结构,存储区间是连续的,占用内存严重,故空间复杂度很大.但数组的二分查找时间复杂度小,为O(1),数组的特点是寻址容易,插入和删除困难.今天学习另外的 ...
- Java集合源码学习(三)LinkedList
前面学习了ArrayList的源码,数组是顺序存储结构,存储区间是连续的,占用内存严重,故空间复杂度很大.但数组的二分查找时间复杂度小,为O(1),数组的特点是寻址容易,插入和删除困难.今天学习另外的 ...
- Java集合源码学习(四)HashMap分析
ArrayList.LinkedList和HashMap的源码是一起看的,横向对比吧,感觉对这三种数据结构的理解加深了很多. >>数组.链表和哈希表结构 数据结构中有数组和链表来实现对数据 ...
- Java集合源码学习(二)ArrayList分析
>>关于ArrayList ArrayList直接继承AbstractList,实现了List. RandomAccess.Cloneable.Serializable接口,为什么叫&qu ...
- Java集合源码学习(一)集合框架概览
>>集合框架 Java集合框架包含了大部分Java开发中用到的数据结构,主要包括List列表.Set集合.Map映射.迭代器(Iterator.Enumeration).工具类(Array ...
- Map集合的便利学习总结
1.Map提供了三种便利方式 1)遍历所有key. Set<K> keySet() 该方法会将当前Map中所有key存入一个Set集合后返回. 2)遍历所有的key-value对 Se ...
- Java集合源码学习(四)HashMap
一.数组.链表和哈希表结构 数据结构中有数组和链表来实现对数据的存储,这两者有不同的应用场景,数组的特点是:寻址容易,插入和删除困难:链表的特点是:寻址困难,插入和删除容易:哈希表的实现结合了这两点, ...
- Java集合源码学习(二)ArrayList
1.关于ArrayList ArrayList直接继承AbstractList,实现了List. RandomAccess.Cloneable.Serializable接口,为什么叫"Arr ...
- Java集合源码学习(一)Collection概览
1.集合框架 Java集合框架包含了大部分Java开发中用到的数据结构,主要包括List列表.Set集合.Map映射.迭代器(Iterator.Enumeration).工具类(Arrays.Coll ...
随机推荐
- java 的类型转换方式
隐式转换 byte等整型转int,最高位(符号位保留),中间补0 byte bt=-13; bt 源码:1000 1101 反码:1111 0010 补码:1111 0011 int it=bt; i ...
- win10与centos7的双系统U盘安装(一:制作u盘启动盘)
博主近来在学习linux系统,当然学习第一步自然是安装系统了,博主选择的是centos7,博主自己的电脑是联想的,系统是win10专业版,在历经数次失败后,博主成功使用u盘安装了win10和cento ...
- PyCharm进行远程开发和调试linux服务器
简介: 或许我也应该迁移到linux环境去开发. 最近写的一些小东西,在wnidows上开发,在windows上调试,都很正常.可是一旦放进linux服务器,就歇菜了. 那么我们有什么办法处理这个wi ...
- CMOS集成门电路
CMOS集成门电路:mos管构成的集成门电路 CMOS:互补对称金属氧化物半导体器件 CMOS反相器电路是由N沟道MOSFET和P沟道MOSFET互补而成:特点静态功耗近视为0,电源电压可在很宽的范围 ...
- 2.12 C++ explicit关键字详解
参考:http://www.cnblogs.com/ymy124/p/3632634.html 总结: 带参数的构造函数中有两种比较常见的构造函数:拷贝构造函数和转型构造函数. 转型构造函数只有一个参 ...
- MATLAB中mexFunction函数的接口规范(转)
reference:https://www.cnblogs.com/haoyul/p/5606720.html https://www.cnblogs.com/zeakey/p/3984733.htm ...
- React 新 Context API 在前端状态管理的实践
本文转载至:今日头条技术博客 众所周知,React的单向数据流模式导致状态只能一级一级的由父组件传递到子组件,在大中型应用中较为繁琐不好管理,通常我们需要使用Redux来帮助我们进行管理,然而随着Re ...
- 使用libcurl下载https地址的文件
使用libcurl下载https地址的文件 void downLoadFile(std::string filename, std::string newFilename) { CURL *curl_ ...
- MySQL:数据库的基本操作
第二篇.数据库的基本操作 一.创建数据库 附:创建数据库并不意味输入数据在这个数据库中,只有用切换数据库才可以输数据到这个数据库中. 1.创建数据库 格式:create database数据库名字 [ ...
- php优秀框架codeigniter学习系列——异常和错误处理机制
这篇介绍下CI框架的异常和错误处理机制. 在入口文件index.php中,根据设置的环境参数设置error_reporting的范围,和是否显示错误. 在CI初始化程序CodeIgniter.php中 ...