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方法总结的更多相关文章

  1. javaSE27天复习总结

    JAVA学习总结    2 第一天    2 1:计算机概述(了解)    2 (1)计算机    2 (2)计算机硬件    2 (3)计算机软件    2 (4)软件开发(理解)    2 (5) ...

  2. mapreduce多文件输出的两方法

    mapreduce多文件输出的两方法   package duogemap;   import java.io.IOException;   import org.apache.hadoop.conf ...

  3. 【.net 深呼吸】细说CodeDom(6):方法参数

    本文老周就给大伙伴们介绍一下方法参数代码的生成. 在开始之前,先补充一下上一篇烂文的内容.在上一篇文章中,老周检讨了 MemberAttributes 枚举的用法,老周此前误以为该枚举不能进行按位操作 ...

  4. IE6、7下html标签间存在空白符,导致渲染后占用多余空白位置的原因及解决方法

    直接上图:原因:该div包含的内容是靠后台进行print操作,输出的.如果没有输出任何内容,浏览器会默认给该空白区域添加空白符.在IE6.7下,浏览器解析渲染时,会认为空白符也是占位置的,默认其具有字 ...

  5. 多线程爬坑之路-Thread和Runable源码解析之基本方法的运用实例

    前面的文章:多线程爬坑之路-学习多线程需要来了解哪些东西?(concurrent并发包的数据结构和线程池,Locks锁,Atomic原子类) 多线程爬坑之路-Thread和Runable源码解析 前面 ...

  6. [C#] C# 基础回顾 - 匿名方法

    C# 基础回顾 - 匿名方法 目录 简介 匿名方法的参数使用范围 委托示例 简介 在 C# 2.0 之前的版本中,我们创建委托的唯一形式 -- 命名方法. 而 C# 2.0 -- 引进了匿名方法,在 ...

  7. ArcGIS 10.0紧凑型切片读写方法

    首先介绍一下ArcGIS10.0的缓存机制: 切片方案 切片方案包括缓存的比例级别.切片尺寸和切片原点.这些属性定义缓存边界的存在位置,在某些客户端中叠加缓存时匹配这些属性十分重要.图像格式和抗锯齿等 ...

  8. [BOT] 一种android中实现“圆角矩形”的方法

    内容简介 文章介绍ImageView(方法也可以应用到其它View)圆角矩形(包括圆形)的一种实现方式,四个角可以分别指定为圆角.思路是利用"Xfermode + Path"来进行 ...

  9. JS 判断数据类型的三种方法

    说到数据类型,我们先理一下JavaScript中常见的几种数据类型: 基本类型:string,number,boolean 特殊类型:undefined,null 引用类型:Object,Functi ...

随机推荐

  1. 利用结果集元数据将查询结果封装为map

    package it.cast.jdbc; import java.sql.Connection; import java.sql.ParameterMetaData; import java.sql ...

  2. App测试

    (1)App独特测试点: 客户端兼容性测试:系统版本.不同深度定制的rom.屏幕分辨率.中断测试.安装.卸载.升级.对其他程序的干扰等 需要的一些工具: appnium / lr /  jmeter ...

  3. VS轻松开发Node.js应用

    PTVS开发团队又开发出一款可以在VS里编写Node.js应用程序的插件--NTVS(Node.js Tools for Visual Studio),开发者可以在VS里轻松开发Node.js应用. ...

  4. 一步步学习javascript基础篇(2):作用域和作用域链

    作用域和作用域链 js的语法用法非常的灵活,且稍不注意就踩坑.这集来分析下作用域和作用域链.我们且从几道题目入手,您可以试着在心里猜想着答案. 问题一. if (true) { var str = & ...

  5. Alljoyn之管中窥豹

    Alljoyn之管中窥豹 一.历史: Alljoyn是高通2011年推出的近距离P2P通讯技术,它为分布式应用程序在不同设备中提供了运行环境,特别是移动性.安全性和动态配置,支持Microsoft W ...

  6. CSharpGL(1)从最简单的例子开始使用CSharpGL

    CSharpGL(1)从最简单的例子开始使用CSharpGL 2016-08-13 由于CSharpGL一直在更新,现在这个教程已经不适用最新的代码了.CSharpGL源码中包含10多个独立的Demo ...

  7. 【Paddy】数据库监控系列(一) - 监控理念

    很多时候,都和身边朋友聊两个问题,DBA的日常工作都是哪些?什么才是数据库方面最重要的? 我相信这两个问题的答案每个人都不会完全一样,我也是,所以这里只代表我的个人观点,并且以下的内容将围绕我的思路展 ...

  8. TDR分辨率

    在日常的生活工作中,有很多测试测量的工具,比如测量长度的尺子,计量时间的钟表等等,谈到测试测量工具的时候,分辨率是关键指标之一,比如尺子的 分辨率是1mm,时钟的分辨率是秒.所谓分辨率就是测试测量工具 ...

  9. Objective-C 装饰模式--简单介绍和使用

    装饰模式是在不必改变原类文件和使用继承的情况下,动态地扩展一个对象的功能.它是通过创建一个包装对象,也就是装饰来包裹真实的对象. 比如游戏机有一个GamePad类, 现在要增加一个作弊功能(例如100 ...

  10. Android Fragment 使用技巧

    1. Fragment 使用时要有一个无参构造函数 如果没有无参构造函数,而是像按照普通类来使用,只创建有参构造函数,则会出现 android.support.v4.app.Fragment$Inst ...