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 集合的更多相关文章

  1. python_way,day3 集合、函数、三元运算、lambda、python的内置函数、字符转换、文件处理

    python_way,day3 一.集合 二.函数 三.三元运算 四.lambda 五.python的内置函数 六.字符转换 七.文件处理 一.集合: 1.集合的特性: 特性:无序,不重复的序列 如果 ...

  2. 跟着ALEX 学python day3集合 文件操作 函数和函数式编程 内置函数

    声明 : 文档内容学习于 http://www.cnblogs.com/xiaozhiqi/  一. 集合 集合是一个无序的,不重复的数据组合,主要作用如下 1.去重 把一个列表变成集合 ,就自动去重 ...

  3. python3入门之集合set

    之前介绍python的数据结构时,没有介绍set(集合)现在在这里稍微介绍下: set原理 Python 还 包 含 了 一 个 数 据 类 型-- set ( 集 合 ) . 集 合 是 一 个 无 ...

  4. Python3字典与集合

    一.Python3字典 字典是另一种可变容器模型,且可存储任意类型对象字典的每个键值(key=>value)对用冒号":"分割,每个键值对之间用逗号"," ...

  5. [Python3] 015 冰冻集合的内置方法

    目录 0. 前言 英文名 元素要求 使用限制 返回 方法数量 1. 如何查看 frozenset() 的内置方法 2. 少废话,上例子 2.1 copy() 2.2 difference() 2.3 ...

  6. Python3基础 set() 集合 创建集合与特点:自动将重复合并掉 不支持索引

    镇场诗: 诚听如来语,顿舍世间名与利.愿做地藏徒,广演是经阎浮提. 愿尽吾所学,成就一良心博客.愿诸后来人,重现智慧清净体.-------------------------------------- ...

  7. python2 => python3 踩坑集合

    报错内容: ModuleNotFoundError: No module named 'md5' 解析: 这是 python2 的库,python3 已经把它包含进 hashlib 库里了 解决方法 ...

  8. python3 set(集合)

    add(增加元素) name = set(['Tom','Lucy','Ben']) name.add('Juny') print(name) #输出:{'Lucy', 'Juny', 'Ben', ...

  9. python3 列表/字典/集合推导式

    '''列表推导式[结果 fox循环 if语句]'''lst = ["Python周末%s期" % i for i in range(1, 27) if i%2 == 0]print ...

随机推荐

  1. Ubuntu 安装Consolas字体

    下载 YaHei.Consolas https://code.google.com/p/uigroupcode/downloads/list 安装 1.创建文件夹 sudo mkdir -p /usr ...

  2. 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 ...

  3. bzoj1509

    树的直径 我先开始以为是个图,想想并不知道什么求图的直径的方法,结果是棵树 那么直觉告诉我们是在直径上面,实际上就是直径+min(i->u,i->v),扫一遍就行了 #include< ...

  4. 学生表、课程表、 成绩表 、教师表sql练习

    转自:http://yuncode.net/code/c_58df7a8ca687e58 1.查询“1”课程比“2”课程成绩高的所有学生的学号: SELECT t1.student_id FROM   ...

  5. 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 ...

  6. bzoj 1616: [Usaco2008 Mar]Cow Travelling游荡的奶牛【dp】

    写了个bfs发现MLE了... 设f[t][i][j]为在t时刻走到(i,j)的方案数,转移和bfs一样 #include<iostream> #include<cstdio> ...

  7. 10.19NOIP模拟赛(DAY2)

    /* 正解O(n)尺取法orz 我写的二分答案.本来以为会被卡成暴力分...... 这个-'0'-48是我写的吗........我怎么不记得... */ #include<bits\stdc++ ...

  8. java 线程开元篇

    学习java的读者都知道,Java的每个对象都会有默认的12个方法,这12个方法分别是 object() finalize() hashCode() equals() wait() wait(long ...

  9. 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 ...

  10. ACM_求补集的交集

    求补集的交集 Time Limit: 2000/1000ms (Java/Others) Problem Description: 给定一个集合,然后再给出两个该集合的子集,求他们对应补集的交集. I ...