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 ...
随机推荐
- codeforces 245H Queries for Number of Palindromes RK Hash + dp
H. Queries for Number of Palindromes time limit per test 5 seconds memory limit per test 256 megabyt ...
- pyhon-----安装yaml踩过的坑以及正解
之前在网上找了各种资料,cmd安装yaml,网上大部分写的都是pip install yaml 可是,执行完就变成Could not find a version that satisfies the ...
- Ural 1158. Censored! 有限状态自动机+DP+大整数
Ural1158 看上去很困难的一道题. 原文地址 http://blog.csdn.net/prolightsfxjh/article/details/54729646 题意:给出n个不同的字符,用 ...
- bzoj1016 [JSOI2008]最小生成树计数——Kruskal+矩阵树定理
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1016 从 Kruskal 算法的过程来考虑产生多种方案的原因,就是边权相同的边有一样的功能, ...
- gitweb
1. 简介 Gitweb提供了git版本库的图形化web浏览功能.可以到网站http://git.kernel.org/体验下效果,如下图所示. Gitweb界面 它既可以通过配置架设于web服务器上 ...
- linux怎么返回上级目录啊,用cd/命令却这样:bash:cd/:没有那个文件或目录
多打一个空格键盘又不会坏.cd 空格 .. 是上一级cd 空格 / 是回最高级,也就是 / 相应的cd 空格 ../../abc 就是去上级目录的上级目录里面的 abc 目录里.Linux 里面,所有 ...
- MySQL 操作语句
解释:|:或;{}:必选;[]:可选 创建数据库并指定字符编码: CREATE {DATABASE|SCHEMA} [IF NOT EXISTS] db_name [DEFAULT] CHARACTE ...
- 1617: [Usaco2008 Mar]River Crossing渡河问题(dp)
1617: [Usaco2008 Mar]River Crossing渡河问题 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 1219 Solved: ...
- Spring boot 分环境部署
一.如果配置文件为:application.properties时 1.application.properties用于填些公共文件 以下为不同环境的配置文件需要单独配置 application-de ...
- c语言数据读入---sscanf、fscanf
#include <iostream> #include <cstdio> #include <cstring> #include <stdlib.h> ...