Python集合及其运算
集合(set)
集合是由不同可hash的值组成的,里面所有的值都是唯一的,也是无序的
集合的创建
>>>set_test = {"name", "age", "hometown"}
## 把值放入{ }中
>>>lis = ("name", "age", "hometown")
>>>set_test = set(lis)
>>> set_test
{'name', 'age', 'hometown'}
##利用set()函数,把其他类型转换为set
>>> list_test = ["name", "age", "hometown"]
>>> set_test = frozenset(list_test)
>>> set_test
frozenset({'name', 'age', 'hometown'})
##利用frozenset()函数可以创造一个set,并把它放到元组里面
集合的操作
add(self, *args, **kwargs)
添加值到集合里面
>>> set_test
{'name', 'age', 'hometown'}
>>> set_test.add("hobby")
>>> set_test
{'name', 'age', 'hobby', 'hometown'}
clear(self, *args, **kwargs)
清空集合
copy(self, *args, **kwargs)
浅拷贝
discard(self, *args, **kwargs)
删除某值,没有时不会报错
>>> set_test
{'name', 'age', 'hobby', 'hometown'}
>>> set_test.discard("hobby")
>>> set_test
{'name', 'age', 'hometown'}
pop(self, *args, **kwargs)
当集合是由列表和元组组成时,set.pop()是从左边删除元素的,并且可以得到被删除的值
>>> set_test
{'name', 'age', 'hometown'}
>>> set_test.pop()
'name'
>>> set_test.pop()
'age'
remove(self, *args, **kwargs)
删除某值,但是如果没有的话,就会报错
>>> set_test = {'name', 'age', 'hometown'}
>>> set_test.remove("hometown")
>>> set_test
{'name', 'age'}
update(self, *args, **kwargs)
更新值,可以在set里面添加多个值
>>> set_test = {"Jack", "Mark", "Ada"}
>>> set_test.update(["Jewish", "Obanma", "Anna"])
>>> print(set_test)
{'Obanma', 'Mark', 'Jack', 'Anna', 'Ada', 'Jewish'}
集合的运算
求交集
>>> set_test1 = {"YuanMing", "Hermaeus", "Chenglong", "Kelan"}
>>> set_test2 = {"YuanMing", "Hermaeus", "ZhangJie","Jack"} >>> test_result = set_test1.intersection(set_test2)
>>> print(test_result)
{'YuanMing', 'Hermaeus'} >>> test_result = set_test1&set_test2
>>> print(test_result)
{'YuanMing', 'Hermaeus'}
求并集
>>> set_test1 = {"YuanMing", "Hermaeus", "Chenglong", "Kelan"}
>>> set_test2 = {"YuanMing", "Hermaeus", "ZhangJie","Jack"} >>> test_result = set_test1.union(set_test2)
>>> print(test_result)
{'Kelan', 'YuanMing', 'ZhangJie', 'Jack', 'Hermaeus', 'Chenglong'} >>> test_result = set_test1|set_test2
>>> print(test_result)
{'Kelan', 'YuanMing', 'ZhangJie', 'Jack', 'Hermaeus', 'Chenglong'}
求差集
>>> set_test1 = {"YuanMing", "Hermaeus", "Chenglong", "Kelan"}
>>> set_test2 = {"YuanMing", "Hermaeus", "ZhangJie","Jack"} >>> test_result = set_test1.difference(set_test2)
>>> test_result1 = set_test1.difference(set_test2)
>>> print(test_result1)
{'Kelan', 'Chenglong'} >>> test_result1 = set_test1-set_test2
>>> print(test_result1)
{'Kelan', 'Chenglong'} >>> test_result2 = set_test2.difference(set_test1)
>>> print(test_result2)
{'ZhangJie', 'Jack'} >>> test_result2 = set_test2-set_test1
>>> print(test_result2)
{'ZhangJie', 'Jack'}
求交叉补集
>>> set_test1 = {"YuanMing", "Hermaeus", "Chenglong", "Kelan"}
>>> set_test2 = {"YuanMing", "Hermaeus", "ZhangJie","Jack"}
>>> test_result = set_test1.symmetric_difference(set_test2)
>>> print(test_result)
{'ZhangJie', 'Jack', 'Kelan', 'Chenglong'}
>>> test_result = set_test1^set_test2
>>> print(test_result)
{'ZhangJie', 'Jack', 'Kelan', 'Chenglong'}
求集赋值
symmetric_difference_update(self, *args, **kwargs)
>>> set_test1 = {"Jack", "Mark", "Devid"}
>>> set_test2 = {"Jack", "Marish", "Good"} >>> set_test1.symmetric_update(set_test2)
>>> set_test1.symmetric_difference_update(set_test2) ## 把得到值赋予set_test1
>>> set_test1, set_test2
({'Good', 'Marish', 'Devid', 'Mark'}, {'Good', 'Jack', 'Marish'}) >>> set_test1 ^= set_test2
>>> set_test1
{'Good', 'Marish', 'Devid', 'Mark'}
intersection_update(self, *args, **kwargs)
>>> set_test1 = {"Jack", "Mark", "Devid"}
>>> set_test2 = {"Jack", "Marish", "Good"} >>> set_test1.intersection_update(set_test2) ##把得到的值赋予set_test1
>>> set_test1, set_test2
({'Jack'}, {'Good', 'Jack', 'Marish'}) >>> set_test1 &= set_test2
>>> set_test1
{'Jack'}
difference_update(self, *args, **kwargs)
>>> set_test1 = {"Jack", "Mark", "Devid"}
>>> set_test2 = {"Jack", "Marish", "Good"} >>> set_test1.difference_update(set_test2)
>>> set_test1, set_test2
({'Devid', 'Mark'}, {'Good', 'Jack', 'Marish'})
>>> set_test1 = {"Jack", "Mark", "Devid"}
>>> set_test2 = {"Jack", "Marish", "Good"} >>> set_test1 -= set_test2
>>> set_test1
{'Devid', 'Mark'}
set_test1 |= set_test2
>>> set_test1 = {"Jack", "Mark", "Devid"}
>>> set_test2 = {"Jack", "Marish", "Good"}
>>> set_test1 |= set_test2
>>> set_test1
子集与父集
issubset(self, *args, **kwargs)
A.issubset(B) A是B的子集吗? 返回bool
>>> set_test2 = {"Jack", "Marish", "Good"}
>>> set_test1 = {"Jack"}
>>> set_test2.issubset(set_test1)
False
>>> set_test1.issubset(set_test2)
True
issuperset(self, *args, **kwargs)
A.issuperset(B) A是B的父集吗? 返回bool
>>> set_test2 = {"Jack", "Marish", "Good"}
>>> set_test1 = {"Jack"}
>>> set_test1.issuperset(set_test2)
False
>>> set_test2.issuperset(set_test1)
True
isdisjoint(self, *args, **kwargs)
返回True如果两个set没有交集
>>> set_test1 = {"Jack", "Mark", "Devid"}
>>> set_test2 = {"Ada", "Marish", "Good"}
>>> set_test1.isdisjoint(set_test2)
True
<,<= OR >,>=
>>> set_test1 = {"Jack", "Mark", "Devid"}
>>> set_test2 = {"Jack", "Mark"
>>> set_test1 < set_test2
False
>>> set_test1 > set_test2
True
Python集合及其运算的更多相关文章
- python集合的运算
& 交集 | 并集 - 差集 ^ 异或集 # 在对集合做运算时,不会影响原来的集合,而是返回一个运算结果 # 创建两个集合 s = {1,2,3,4,5} s2 = {3,4,5, ...
- 初学Python——集合及其运算
一.集合定义及其功能 集合是一个无序的.不重复的数据组合,和字典列表一样也是一种数据类型. 集合两个最主要的功能:①去重(把一个列表变成集合,就自动去重了) ②关系测试(测试两组数据之间的交.并.差集 ...
- day14 Python集合关系运算交,差,并集
low逼写法,没用集合 python_1 = ['charon','pluto','ran'] linux_1 = ['ran','xuexue','ting'] python_and_linux = ...
- python 集合的运算
x = frozenset([, , , , ]) y = frozenset([, , , , ]) #如果x与y没有公共元素,返回true print(x.isdisjoint(y)) #返回x与 ...
- Python全栈之路3--set集合--三元运算--深浅拷贝--初识函数
一.上节课的重点回顾: 1.类名加括号其实就是执行类的__init__方法: 2.int a.创建方式 n1 = 123 #根据int类创建了一个对象 n2 = int(123) #根据int类创建一 ...
- python集合类型
集合类型简介 集合也是容器,其内元素都是无序.唯一.不可变的.它常用来做成员测试.移除重复数据.数据计算(比如交集.并集.差集). 集合Set是dict的无value版.集合也使用大括号包围: > ...
- python集合与字典的用法
python集合与字典的用法 集合: 1.增加 add 2.删除 •del 删除集合 •discard(常用)删除集合中的元素 #删除一个不存在的元素不会报错 •remove 删除一个不存在的 ...
- Python—集合的操作、文件的操作
1.集合的操作 2.文件的操作 1.集合的操作 定义: 1.不同元素组成,自动去重 2.无序 3.集合中的元素必须是不可变类型 1.集合的定义: >>> s1 = set('abcd ...
- python集合、元组、字典
主要内容: 2.集合 3.元组 4.字典 复习: 字符串和元组一样,只能读不能写.列表和字典可以嵌套任何东西,列表可以嵌套列表 L = list("hello") # L = [ ...
随机推荐
- java操作elasticsearch实现前缀查询、wildcard、fuzzy模糊查询、ids查询
1.前缀查询(prefix) //prefix前缀查询 @Test public void test15() throws UnknownHostException { //1.指定es集群 clus ...
- Java多线程(三)如何创建线程
点我跳过黑哥的卑鄙广告行为,进入正文. Java多线程系列更新中~ 正式篇: Java多线程(一) 什么是线程 Java多线程(二)关于多线程的CPU密集型和IO密集型这件事 Java多线程(三)如何 ...
- 译文——The habits of highly successful people
1.Morning Routine (早上列行公事) Probably the most common habit ultra-successful people have is they can t ...
- 合并两个有序数组的golang实现
给定两个有序整数数组 nums1 和 nums2,将 nums2 合并到 nums1 中,使得 num1 成为一个有序数组. 说明: 初始化 nums1 和 nums2 的元素数量分别为 m 和 n. ...
- Fluentd初探 简介与安装
Fluentd是一个开源的数据收集器,专为处理数据流设计,有点像 syslogd ,但是使用JSON作为数据格式.它采用了插件式的架构,具有高可扩展性高可用性,同时还实现了高可靠的信息转发. 据分(Y ...
- Ubuntu下导入PySpark到Shell和Pycharm中(未整理)
实习后面需要用到spark,虽然之前跟了edX的spark的课程以及用spark进行machine learning,但那个环境是官方已经搭建好的,但要在自己的系统里将PySpark导入shell(或 ...
- 渐进式迭代教学法--PHP
渐进式迭代教学法--PHP 目前常见的课程体系大致情况如下: 阶段1:前端基础(html+css+js) 阶段2:PHP&MySQL基础 + 框架 (PHP基本语法,面向对象,mvc,sql基 ...
- zabbix 应用监控作业笔记 ansible-playbook
目录 目录结构 zabbix-web.yaml zabbix-backup.yaml zabbix-nfs.yaml zabbix-mysql.yaml zabbix-server.yaml zabb ...
- flask上传excel文件,无须存储,直接读取内容
运行环境python3.6 import xlrd from flask import Flask, request app = Flask(__name__) @app.route("/& ...
- Error: Cannot find module 'babel-runtime/regenerator'
在做调用阿里云短信接口时遇到的一个问题 错误原因:没有正确安装相应的mmodule 解决办法: 第一步:在package.json中加入依赖label-runtime 第二步:在Terminal中 n ...