Python_Day_04 set方法总结
set(集合)
- 直接创建一个空集合
set_empty = set()
print(set_empty) # set()
- 根据参数创建
# 根据参数
set_argument = set(42,'','ry')
print(set_argument) # 这样会报错,因为set只允许有一个参数
- 根据列表来创建
set_list = set([11,11,'','','ee'])
print(set_list) # {11, 'ee', '45', '11'} 会自动删除重复对象
- 根据元组来创建
set_tuple = set((11,11,'','','ee',))
print(set_tuple) # {'ee', 11, '45', '11'} 同样会自动删除重复对象
- 根据字典来创建
set_dict = set({'k1':'v1','k2':2,'k3':'v3','k1':'v4'})
print(set_dict) # {'k3', 'k1', 'k2'} 只会存储key值,且不会重复
- 字符串创建
set_str = set('Hello Python')
print(set_str) # {'y', 'o', 'n', ' ', 'P', 't', 'h', 'H', 'e', 'l'} 同样会删除字符串中重复的字符
- add(self, *args, **kwargs) 添加一个新的元素到集合中,如果添加的元素在集合中已经存在就不会有任何操作
set_init = set([11,11,'','','ee'])
set_init.add('Hello')
print(set_init) # {'Hello', 11, 'ee', '11', '45'} set_init_str = set('Python')
set_init_str.add('Hello,World')
print(set_init_str) # {'Hello,World', 'o', 'P', 't', 'n', 'y', 'h'}
- clear(self, *args, **kwargs) 清除集合中元素,可以传参数
set_init_clear = set([11,11,'','','ee'])
set_init_clear.clear()
print(set_init_clear) # set()
- copy(self, *args, **kwargs) 浅拷贝,会返回一个新的集合
set_init_copy = set([11,11,'','','ee'])
set_receive_copy = set_init_copy.copy()
print(set_receive_copy) # {'ee', 11, '45', '11'}
- difference(self, *args, **kwargs) 比较两个集合类的不同,返回的是被主动比较的那个集合与比较集合的交集之外的子集(数学上叫啥给忘了)
set_init_dif1 = set([11,22,33,44])
set_init_dif2 = set([33,44,55,66])
set_init_rece1 = set_init_dif1.difference(set_init_dif2)
print(set_init_rece1) # {11, 22}
set_init_rece2 = set_init_dif2.difference(set_init_dif1)
print(set_init_rece2) # {66, 55}
- difference_update(self, *args, **kwargs) 删除两个集合的交际
set_init_upd1 = set([11,22,33,44])
set_init_upd2 = set([33,44,55,66])
set_init_upd1.difference_update(set_init_upd2)
print(set_init_upd1) # {22, 11} set_init_upd3 = set([11,22,33,44])
set_init_upd4 = set([33,44,55,66])
set_init_upd4.difference_update(set_init_upd3)
print(set_init_upd4) # {66, 55}
- discard(self, *args, **kwargs) 删除集合中存在的元素,如果不存在就什么也不做
set_init_dis = set([11,22,33,44,55])
set_init_dis.discard(11)
print(set_init_dis) # {33, 44, 22, 55} 只能删除一个
- intersection(self, *args, **kwargs) 返回两个集合中的交集
set_init_inter1 = set([11,22,33,44])
set_init_inter2 = set([33,44,55,66])
set_rece_inter1 = set_init_inter1.intersection(set_init_inter2)
print(set_rece_inter1) # {33, 44}
- intersection_update(self, *args, **kwargs) 取出两个集合的交集,更新一个集合
set_inter_upd1 = set([111,222,333,444])
set_inter_upd2 = set([333,444,55,66])
set_inter_upd1.intersection_update(set_inter_upd2)
print(set_inter_upd1) # {444, 333}
- isdisjoint(self, *args, **kwargs) 判断两个集合是否有交集,如果有就返回False,如果没有就返回Ture
set_isdis1 = set([111,222,333,444])
set_isdis2 = set([222,333])
set_receive_isdis1 = set_isdis1.isdisjoint(set_isdis2)
print(set_receive_isdis1) # False 说明有交集
- issubset(self, *args, **kwargs) 判断A集合是否是B集合的子集
set_issub1 = set([111,222,333,444])
set_issub2 = set([222,333])
set_receive_issub1 = set_issub1.issubset(set_issub2)
print(set_receive_issub1) # False 说明set_issub1不是set_issub2的子集
set_receive_issub2 = set_issub2.issubset(set_issub1)
print(set_receive_issub2) # True 说明set_issub2是set_issub1的子集
- issuperset(self, *args, **kwargs) 判断A集合是否是B集合的父类,就是A集合是否包含B集合.结果跟 issubset(self, *args, **kwargs) 相反
- pop(self, *args, **kwargs) 移除元素,同时可以定义一个变量来接收移除的元素,如果集合为空会报错
set_pop = set([111,222,333,444,232])
set_receive_pop = set_pop.pop()
print(set_pop) # {444, 333, 222, 111}
print(set_receive_pop) #
- remove(self, *args, **kwargs) 删除元素
set_remove = set([111,222,333,444,232])
set_remove.remove(111)
print(set_remove) # {232, 444, 333, 222}
- symmetric_difference(self, *args, **kwargs) 取出两个差,更新到一个集合中,如果同时删除A,B两集合中相同元素删除.
set_sym1 = set([1,2,3,4,5])
set_sym2 = set([2,3,4,5,6,])
set_receive_sym1 = set_sym1.symmetric_difference(set_sym2)
print(set_receive_sym1) # {1, 6} set_sym3 = set([1,2,3,4,5])
set_sym4 = set([6,])
set_receive_sym2 = set_sym3.symmetric_difference(set_sym4)
print(set_receive_sym2) # {1, 2, 3, 4, 5, 6}
- symmetric_difference_update(self, *args, **kwargs) 将B集合中有,而A集合中没有的更新到A集合中
set_sym_up1 = set([1,2,3,4,5])
set_sym_up2 = set([2,3,4,5,6,])
set_sym_up1.symmetric_difference_update(set_sym_up2)
print(set_sym_up1) # {1, 6} set_sym_up3 = set([1,2,3,4,5])
set_sym_up4 = set([6,])
set_sym_up3.symmetric_difference_update(set_sym_up4)
print(set_sym_up3) # {1, 2, 3, 4, 5, 6}
- union(self, *args, **kwargs) 返回A集合和B集合的并集
set_un1= set([11,22,33,44])
set_un2 = set([22,33,44,55])
set_rec_un = set_un1.union(set_un2)
print(set_rec_un) # {33, 11, 44, 22, 55}
- update(self, *args, **kwargs) A和B的并集,并返回A
set_un_up1 = set([111,222,333,444])
set_un_up2 = set([222,333,444,555])
set_un_up1.update(set_un_up2)
print(set_un_up1) # {555, 333, 111, 444, 222}
Python_Day_04 set方法总结的更多相关文章
- javaSE27天复习总结
JAVA学习总结 2 第一天 2 1:计算机概述(了解) 2 (1)计算机 2 (2)计算机硬件 2 (3)计算机软件 2 (4)软件开发(理解) 2 (5) ...
- mapreduce多文件输出的两方法
mapreduce多文件输出的两方法 package duogemap; import java.io.IOException; import org.apache.hadoop.conf ...
- 【.net 深呼吸】细说CodeDom(6):方法参数
本文老周就给大伙伴们介绍一下方法参数代码的生成. 在开始之前,先补充一下上一篇烂文的内容.在上一篇文章中,老周检讨了 MemberAttributes 枚举的用法,老周此前误以为该枚举不能进行按位操作 ...
- IE6、7下html标签间存在空白符,导致渲染后占用多余空白位置的原因及解决方法
直接上图:原因:该div包含的内容是靠后台进行print操作,输出的.如果没有输出任何内容,浏览器会默认给该空白区域添加空白符.在IE6.7下,浏览器解析渲染时,会认为空白符也是占位置的,默认其具有字 ...
- 多线程爬坑之路-Thread和Runable源码解析之基本方法的运用实例
前面的文章:多线程爬坑之路-学习多线程需要来了解哪些东西?(concurrent并发包的数据结构和线程池,Locks锁,Atomic原子类) 多线程爬坑之路-Thread和Runable源码解析 前面 ...
- [C#] C# 基础回顾 - 匿名方法
C# 基础回顾 - 匿名方法 目录 简介 匿名方法的参数使用范围 委托示例 简介 在 C# 2.0 之前的版本中,我们创建委托的唯一形式 -- 命名方法. 而 C# 2.0 -- 引进了匿名方法,在 ...
- ArcGIS 10.0紧凑型切片读写方法
首先介绍一下ArcGIS10.0的缓存机制: 切片方案 切片方案包括缓存的比例级别.切片尺寸和切片原点.这些属性定义缓存边界的存在位置,在某些客户端中叠加缓存时匹配这些属性十分重要.图像格式和抗锯齿等 ...
- [BOT] 一种android中实现“圆角矩形”的方法
内容简介 文章介绍ImageView(方法也可以应用到其它View)圆角矩形(包括圆形)的一种实现方式,四个角可以分别指定为圆角.思路是利用"Xfermode + Path"来进行 ...
- JS 判断数据类型的三种方法
说到数据类型,我们先理一下JavaScript中常见的几种数据类型: 基本类型:string,number,boolean 特殊类型:undefined,null 引用类型:Object,Functi ...
随机推荐
- (翻译)《Hands-on Node.js》—— Introduction
今天开始会和大熊君{{bb}}一起着手翻译node的系列外文书籍,大熊负责翻译<Node.js IN ACTION>一书,而我暂时负责翻译这本<Hands-on Node.js> ...
- MyBatis(跨表查询)
1.建立数据库表如下: DROP TABLE IF EXISTS t_demo_user; CREATE TABLE IF NOT EXISTS t_demo_user( userid ), user ...
- windows下Meteor+AngularJS开发的坑
有复杂的地方我再开贴记录,这里只记录容易解决的坑. 1. windows下手工增加smart package.直接将下载下来的包扔到meteor package中.记得将文件夹名字改得和smart.j ...
- MapReduce剖析笔记之一:从WordCount理解MapReduce的几个阶段
WordCount是一个入门的MapReduce程序(从src\examples\org\apache\hadoop\examples粘贴过来的): package org.apache.hadoop ...
- 七天学会ASP.NET MVC (五)——Layout页面使用和用户角色管理
系列文章 七天学会ASP.NET MVC (一)——深入理解ASP.NET MVC 七天学会ASP.NET MVC (二)——ASP.NET MVC 数据传递 七天学会ASP.NET MVC (三)— ...
- TODO:Golang UDP连接简单测试慎用Deadline
TODO:Golang UDP连接简单测试慎用Deadline UDP 是User Datagram Protocol的简称, 中文名是用户数据报协议,是OSI(Open System Interco ...
- Java 浅析三大特性之一多态
Java 浅析三大特性之一多态 之前我们的文章讲了Java的封装和继承,封装讲的时候,并没有体现出来封装的强大之处,反而还要慎用封装.因为这时的封装还没有和多态联系到一起,还无法看出向上转型的厉害之处 ...
- crossplatfrom---electron入门教程
1.atom/electron github: https://github.com/atom/electron 中文文档: https://github.com/atom/electron/tree ...
- 史上最全的 Redux 源码分析
前言 用 React + Redux 已经一段时间了,记得刚开始用Redux 的时候感觉非常绕,总搞不起里面的关系,如果大家用一段时间Redux又看了它的源码话,对你的理解会有很大的帮助.看完后,在回 ...
- ionic中关于ionicView 的生命周期
当我们来回切换页面时候,视图被缓存下来,不用每次再去new一个新的视图,可以大大地提高性能.当跳出一个视图后,视图的元素被保存在DOM中,它的作用域也就不在$watch的作用域内,当我们访问一个已经被 ...