python3.x Day3 集合
python中的集合
集合定义:一个无序的去重的数据集,主要特性就是去重和关系测试,关系测试不改变集合中的数据值
定义集合:set(list) 可以将list转化为集合set
示例:
定义一个集合:list_1
list_1=[1,3,23,53,3]
定义另一个集合:list_2
list_2=[2,3,53,2]
转化为集合:
可以用list_1自身转化,也可以赋值给其他变量,这里就用自身
list_1 = set(list_1)
list_2 = set(list_2)
输出一下转化后的值,可以看到已经去重了(去重特性):
print(list_1,type(list_1))
print(list_2,type(list_2))
#结果:
>>> print(list_1,type(list_1))
{1, 3, 53, 23} <class 'set'> >>> print(list_2,type(list_2))
{2, 3, 53} <class 'set'>
接下来是关系测试:
交集(list_1、list_2都有的数据):可以用set的intersection方法(以下代码)或者运算符 print(list_1 & list_2)
#交集
print(list_1.intersection(list_2))
>>>{3, 53}
判断 没有交集(没有:True、有:False):
#判断 没有交集
print("判断 没有交集,没有返回True")
print(list_1.isdisjoint(list_2)) #有交集,返回false
list_4=set([101,102]) #定义list_4与list_1没有交集
print("list_4:",list_4)
print(list_1.isdisjoint(list_4)) >>>判断 没有交集,没有返回True
>>>False
>>>list_4: {101, 102}
>>>True
并集(list_1、list_2中的数据整合在一起):可以用set的union方法,也可以使用运算符print( list_1 | list_2 )
#并集
print(list_1.union(list_2))
>>>{1, 2, 3, 53, 23}
差集(取数据为:首先在list_1中,list_2中的数据,如果list_1中有,结果集就去掉):可以用set的difference方法,也可以使用运算符print( list_1 - list_2 ) 表示:list_1中包含,list_2不包含
#差集
print(list_1.difference(list_2))
>>>{1, 23}
#反过来也是一样的原理,结果以list_2为准
print(list_2.difference(list_1))
>>>{2}
对称差集(取得两个集合互相都没有的数据):可以使用set对象的symmetric_difference方法,也可以使用运算符 print( list_1 ^ list_2)
#对称差集:取得两个集合中,互相都没有的数据
print("对称差集")
#list_1、list_2
print(list_1,list_2)
#取得对称差集
print(list_1.symmetric_difference(list_2)) >>>{1, 3, 53, 23} {2, 3, 53}
>>>{1, 2, 23}
子集/父集:
#子集/父集 返回值为True、False
print("子集/父集")
print(list_1.issubset(list_2)) #list_1是不是list_2的子集
print(list_1.issuperset(list_2)) #list_1是不是list_2的父集
>>>False
>>>False list_3=set([3,53])
print(list_3.issubset(list_1))#list_3是不是list_1的子集
print(list_1.issuperset(list_3))#list_1是不是list_3的父集
>>>True
>>>True
集合的增伤改查:
#集合的增删改查
print("增加,add方法增加一个,update方法增加多个")
list_1.add(55555)
list_1.update([333,444,666])
print("查询,len()方法查询有多少成员,x in set判断x是否为成员")
print(list_1)
print(len(list_1))
print(666 in list_1,999 in list_1)
print("删除,set的pop方法随机删除一个,返回被删除的值。"
"remove删除指定一个成员,有就删除,没有就异常,"
"discard方法删除指定值,不返回,有就删除,没有就啥都不做")
print("it is {list}".format(list=list_1))
print(list_1.pop())
print("pop():",list_1)
#remove
list_1.remove(333)
#list_1.remove("ddd") ddd不存在,此处会异常
print("remove()",list_1)
#discard
list_1.discard(444)
list_1.discard("ddd")
print(list_1)
python3.x Day3 集合的更多相关文章
- python_way,day3 集合、函数、三元运算、lambda、python的内置函数、字符转换、文件处理
python_way,day3 一.集合 二.函数 三.三元运算 四.lambda 五.python的内置函数 六.字符转换 七.文件处理 一.集合: 1.集合的特性: 特性:无序,不重复的序列 如果 ...
- 跟着ALEX 学python day3集合 文件操作 函数和函数式编程 内置函数
声明 : 文档内容学习于 http://www.cnblogs.com/xiaozhiqi/ 一. 集合 集合是一个无序的,不重复的数据组合,主要作用如下 1.去重 把一个列表变成集合 ,就自动去重 ...
- python3入门之集合set
之前介绍python的数据结构时,没有介绍set(集合)现在在这里稍微介绍下: set原理 Python 还 包 含 了 一 个 数 据 类 型-- set ( 集 合 ) . 集 合 是 一 个 无 ...
- Python3字典与集合
一.Python3字典 字典是另一种可变容器模型,且可存储任意类型对象字典的每个键值(key=>value)对用冒号":"分割,每个键值对之间用逗号"," ...
- [Python3] 015 冰冻集合的内置方法
目录 0. 前言 英文名 元素要求 使用限制 返回 方法数量 1. 如何查看 frozenset() 的内置方法 2. 少废话,上例子 2.1 copy() 2.2 difference() 2.3 ...
- Python3基础 set() 集合 创建集合与特点:自动将重复合并掉 不支持索引
镇场诗: 诚听如来语,顿舍世间名与利.愿做地藏徒,广演是经阎浮提. 愿尽吾所学,成就一良心博客.愿诸后来人,重现智慧清净体.-------------------------------------- ...
- python2 => python3 踩坑集合
报错内容: ModuleNotFoundError: No module named 'md5' 解析: 这是 python2 的库,python3 已经把它包含进 hashlib 库里了 解决方法 ...
- python3 set(集合)
add(增加元素) name = set(['Tom','Lucy','Ben']) name.add('Juny') print(name) #输出:{'Lucy', 'Juny', 'Ben', ...
- python3 列表/字典/集合推导式
'''列表推导式[结果 fox循环 if语句]'''lst = ["Python周末%s期" % i for i in range(1, 27) if i%2 == 0]print ...
随机推荐
- Ubuntu 安装Consolas字体
下载 YaHei.Consolas https://code.google.com/p/uigroupcode/downloads/list 安装 1.创建文件夹 sudo mkdir -p /usr ...
- codeforces 963B Destruction of a Tree
B. Destruction of a Tree time limit per test 1 second memory limit per test 256 megabytes input stan ...
- bzoj1509
树的直径 我先开始以为是个图,想想并不知道什么求图的直径的方法,结果是棵树 那么直觉告诉我们是在直径上面,实际上就是直径+min(i->u,i->v),扫一遍就行了 #include< ...
- 学生表、课程表、 成绩表 、教师表sql练习
转自:http://yuncode.net/code/c_58df7a8ca687e58 1.查询“1”课程比“2”课程成绩高的所有学生的学号: SELECT t1.student_id FROM ...
- A brief preview of the new features introduced by OpenGL 3.3 and 4.0
A brief preview of the new features introduced by OpenGL 3.3 and 4.0 The Khronos Group continues t ...
- bzoj 1616: [Usaco2008 Mar]Cow Travelling游荡的奶牛【dp】
写了个bfs发现MLE了... 设f[t][i][j]为在t时刻走到(i,j)的方案数,转移和bfs一样 #include<iostream> #include<cstdio> ...
- 10.19NOIP模拟赛(DAY2)
/* 正解O(n)尺取法orz 我写的二分答案.本来以为会被卡成暴力分...... 这个-'0'-48是我写的吗........我怎么不记得... */ #include<bits\stdc++ ...
- java 线程开元篇
学习java的读者都知道,Java的每个对象都会有默认的12个方法,这12个方法分别是 object() finalize() hashCode() equals() wait() wait(long ...
- mycat重启报错Failed to connect to the Wrapper at port解决方法
报错信息 ERROR | wrapper | 2018/05/11 14:01:55 | Startup failed: Timed out waiting for a signal from the ...
- ACM_求补集的交集
求补集的交集 Time Limit: 2000/1000ms (Java/Others) Problem Description: 给定一个集合,然后再给出两个该集合的子集,求他们对应补集的交集. I ...