集合的定义:

由不同元素组成、一组无序排列的可hash值、集合中元素必须是不可变类型

  集合的定义方式:
  由大括号组成;
  每个元素用逗号分隔;
  元素书写不是key-value形式;

集合是由不同元素组成,如果在集合中使用相同元素,会自动处理
例如:

s={1,2,3,3,44,33,33,4,4,5,5,7}
type(s)
print(s)
返回结果:
{33, 2, 3, 4, 5, 1, 7, 44}

集合是无序的:
例如:

s={'a','h','o','n','b','d','c'}
for item in s:
print(item)
返回结果:
n
o
c
h
d
a
b

集合的书写定义格式:
格式1:
  s={element1,element2,element3...}
  element都为不变类型

格式2:
  s=set(<可迭代类型>)
  可迭代类型:字符串、列表、元组、字典

例如:定义格式2

s=set([1,2,3,"hello"]) #遍历列表,把每个元素当作集合中的一个值
print(s)
返回结果:
{1, 2, 3, 'hello'} s=set((1,2,3))
print(s)
返回结果:
{1, 2, 3} s=set({'k1':'v1','k2':'v2'}) #以逗号分隔,遍历字典,得到值后不再继续遍历
print(s)
返回结果:
{'k2', 'k1'} s=set('hello')
print(s)
返回结果:
{'e', 'o', 'h', 'l'} s=set("hello")
print(s)
返回结果:
{'e', 'o', 'h', 'l'}

********集合的方法:********

1.add()方法:向集合中添加元素

s={1,2,3}
s.add('s')
print(s)
返回结果:
{1, 2, 3, 's'}

2.clear()方法:清空集合

3.copy()方法:复制集合

4.pop()方法:从集合中随机删除一个元素,不特定的顺序删除
  pop方法可以把删除的元素赋值给变量
例如:

s={'sss',1,2,3}
v=s.pop()
print(v,s)
返回结果:
1 {2, 3, 'sss'}

5.remove()方法:从集合中指定删除一个元素
格式:
  S.remove(<element>)
如果指定的element在集合中不存在,则报错
例如:

s={'sss',1,2,3}
s.remove('sss') #注意要使用引号
print(s)
返回结果:
{1, 2, 3}

6.discard()方法:指定元素删除,如果指定元素不存在,则不会报错

********集合的关系操作及其方法********

1.
intersecion()方法:获取2个集合的交集
格式1:
  S1.intersection(<S2>)
格式2:
  S1&S2
例如:

python_l=['lcg','szw','zjw']
linux_l=['lcg','szw']
p_s=set(python_l)
l_s=set(linux_l)
v=p_s.intersection(l_s)
print(v)
返回结果:
{'szw', 'lcg'} 或者
v=p_s&l_s
print(v)

2.
union()方法:获取2个集合的并集,组成一个集合,并且去重
格式1:
  S1.union(<S2>)
格式2:
  S1|S2
例如:

python_l=['lcg','szw','zjw']
linux_l=['lcg','szw']
p_s=set(python_l)
l_s=set(linux_l)
v=p_s.union(l_s)
print(v)
返回结果:
{'zjw', 'lcg', 'szw'} 或者
v=p_s|l_s
print(v)

3.
difference()方法:生成2个集合的差集,表示在左面的集合中,只存在于左面集合,在右面集合没有的元素
格式1:
  S1.difference(<S2>)
格式2:
  S1-S2
例如:

python_l=['lcg','szw','zjw']
linux_l=['lcg','szw']
p_s=set(python_l)
l_s=set(linux_l)
v=p_s.difference(l_s)
print(v)
返回结果:
{'zjw'} 或者
v=p_s-l_s
print(v)

4.
symmetric_difference()方法:集合的交差补集
格式1:
  S1.symmetric_difference(<S2>)
格式2:
  S1^S2
例如:

python_l=['lcg','szw','zjw']
linux_l=['lcg','szw']
p_s=set(python_l)
l_s=set(linux_l)
v=p_s.symmetric_difference(l_s)
print(v)
返回结果:
{'zjw'}

5.
difference_update()方法:两个集合做完差集(difference)之后,把结果更新回去
格式
  S1.difference_update(<S2>)
  S1与S2作差集,然后把结果赋值给S1

例如:

python_l=['lcg','szw','zjw']
linux_l=['lcg','szw']
p_s=set(python_l)
l_s=set(linux_l)
p_s.difference_update(l_s)
print(p_s)
返回结果:
{'zjw'}

6.
intersection_update()方法:两个集合做交集(intersection),把结果更新回去
格式:
  S1.intersection_update(S2)
  S1与S2作交集,然后把结果赋值给S1
例如:

python_l=['lcg','szw','zjw']
linux_l=['lcg','szw']
p_s=set(python_l)
l_s=set(linux_l)
p_s.intersection_update(l_s)
print(p_s)
返回结果:
{'lcg', 'szw'}

7.
isdisjoint()方法:如果两个集合交集之后,没有结果,返回True,就是两个集合没有交集就返回True
格式:
  S1.isdisjoint(S2)
例如:

s1={1,2}
s2={3,5}
v=s1.isdisjoint(s2)
print(v)
返回结果:
True s1={1,2,3,}
s2={2,4,9}
v=s1.isdisjoint(s2)
print(v)
返回结果:
False

8.
issubset()方法:返回一个集合是否是另一个集合的子集合,是子集合返回True,否则返回False
格式:
  S1.issubset(S2)
例如:

s1={1,2}
s2={1,2,3}
v=s1.issubset(s2)
print(v)
返回结果:
True

9.
issuperset()方法:返回一个集合是否是另一个集合的父集、超集,是返回True,否则返回False
格式:
  S1.issuperset(S2)
例如:

s1={1,2}
s2={1,2,3}
v=s2.issuperset(s1)
print(v)
返回结果:
True

10.
update()方法:将可迭代对象(字符串、元组、列表、集合)做并集,把结果更新回去
格式:
  S1.update(<可迭代对象>)
  作并集之后,把结果赋值给S1

例如:

s1={1,2}
s2={1,2,3}
s1.update(s2)
print(s1)
返回结果:
{1, 2, 3}

python之集合及其方法---整理集的更多相关文章

  1. python之字典及其方法---整理集

    字典 特点: 使用逗号分隔的key:value形式: 使用大括号括起来: key-value的键值对中,value部分可以是任意类型: 列表.字典不能做为字典的key: 字典是无序的,哪个key-va ...

  2. python之元组及其方法---整理集

    元组: 区别:与列表类似,是对列表的二次加工:用小括号包括起来:元素不可修改:不可增加.删除 技巧:创建元组的时候,一般在最后一个元素后面加一个逗号:为了与方法区分:并且这个逗号不算元素例如: tu= ...

  3. python之列表及其方法---整理集

    列表类,类名是list 通过list类创建对象,使用中括号 列表特性: 使用中括号括起来 中间用逗号分隔每个元素 元素可以是数字.字符串.布尔值.列表 列表中可以嵌套列表 列表中每个元素的下标从0开始 ...

  4. python之字符串及其方法---整理集

    字符串方法 1.capitalize方法:字符串首字母大写 举例: test="alex" v=test.capitalize() print(v) 返回结果: Alex 2.ca ...

  5. java 调用 python 的几种方法整理

    参考:   https://blog.csdn.net/secondlieutenant/article/details/79000265

  6. Python爬虫防封杀方法集合

      Python爬虫防封杀方法集合     mrlevo520 2016.09.01 14:20* 阅读 2263喜欢 38       Python 2.7 IDE Pycharm 5.0.3 前言 ...

  7. python字符串操作实方法大合集

    python字符串操作实方法大合集,包括了几乎所有常用的python字符串操作,如字符串的替换.删除.截取.复制.连接.比较.查找.分割等,需要的朋友可以参考下:   #1.去空格及特殊符号 s.st ...

  8. 编程中遇到的Python错误和解决方法汇总整理

    这篇文章主要介绍了自己编程中遇到的Python错误和解决方法汇总整理,本文收集整理了较多的案例,需要的朋友可以参考下   开个贴,用于记录平时经常碰到的Python的错误同时对导致错误的原因进行分析, ...

  9. Python的集合

    1. Python的集合 1.1 集合的定义 在Python中, 集合set是基本数据类型的一种集合类型,它有可变集合(set())和不可变集合(frozenset)两种.Python中的集合set类 ...

随机推荐

  1. 一个HTTP打趴80%面试者

    面试多年,每当我问起面试者对HTTP的了解时,个个回答令我瞠目结舌,这些开发者都有3-5年的经验.请不要让我叫你野生程序员,是时候了解HTTP了,让我们当个正规军. 起因 面试官:请问你了解HTTP协 ...

  2. 3.Qt GUI中一些操作记录

    一.如何在Widget中利用代码添加背景图片 this->setAutoFillBackground(true); // QPalette palette = this->palette( ...

  3. nvidia驱动自动更新版本后问题解决 -- failed to initialize nvml: driver/library version mismatch

    因为必须关闭桌面窗口, 建议另外一台电脑ssh连接操作 1. 卸载旧版本并关闭图形界面 sudo apt-get remove --purge nvidia-\* sudo service light ...

  4. windows环境 springboot+docker开发环境搭建与hello word

    1,下载安装 docker toolbox 下载地址:http://mirrors.aliyun.com/docker-toolbox/windows/docker-toolbox/ docker t ...

  5. Scrapy CrawlSpider源码分析

    crawl.py中主要包含两个类: 1. CrawlSpider 2. Rule link_extractor:传LinkExtractor实例对象 callback:传”func_name“ cb_ ...

  6. Spark-RPC理解

    基本架构 Akka Actor式RPC架构 Spark采用的是AkkaActor架构实现RPC,但是实际使用过程为了兼容不同节点之间的文件下载,采用Netty来实现Actor功能. Spark RPC ...

  7. java+Selenium+TestNg搭建自动化测试架构(3)实现POM(page+Object+modal)

    1.Page Object是Selenium自动化测试项目开发实践的最佳设计模式之一,通过对界面元素的封装减少冗余代码,同时在后期维护中,若元素定位发生变化,只需要调整页面元素封装的代码,提高测试用例 ...

  8. JavaScript数组方法--concat、push

    利用了两天的时间,使用typescript和原生js重构了一下JavaScript中数组对象的主要方法,可以移步github查看. 这里,按照MDN上的文档顺序,再重新学习一下数组方法吧. conca ...

  9. Android 开发 将window变暗

    前言 在创建弹窗功能时,一般有需求将背景的window界面变暗.下面两组代码就实现了变暗与恢复的功能. 变暗 public void startDark(){ WindowManager.Layout ...

  10. expdp/impdp数据泵分区表导入太慢了。添加不检查元数据参数提高效率:ACCESS_METHOD=DIRECT_PATH

    分区表数据泵导入太慢,达不到客户的迁移要求导出语句如下:(10G单节点)userid='/ as sysdba'directory=milk_dirdumpfile=mon_%U.dmplogfile ...