python之集合及其方法---整理集
集合的定义:
由不同元素组成、一组无序排列的可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之集合及其方法---整理集的更多相关文章
- python之字典及其方法---整理集
字典 特点: 使用逗号分隔的key:value形式: 使用大括号括起来: key-value的键值对中,value部分可以是任意类型: 列表.字典不能做为字典的key: 字典是无序的,哪个key-va ...
- python之元组及其方法---整理集
元组: 区别:与列表类似,是对列表的二次加工:用小括号包括起来:元素不可修改:不可增加.删除 技巧:创建元组的时候,一般在最后一个元素后面加一个逗号:为了与方法区分:并且这个逗号不算元素例如: tu= ...
- python之列表及其方法---整理集
列表类,类名是list 通过list类创建对象,使用中括号 列表特性: 使用中括号括起来 中间用逗号分隔每个元素 元素可以是数字.字符串.布尔值.列表 列表中可以嵌套列表 列表中每个元素的下标从0开始 ...
- python之字符串及其方法---整理集
字符串方法 1.capitalize方法:字符串首字母大写 举例: test="alex" v=test.capitalize() print(v) 返回结果: Alex 2.ca ...
- java 调用 python 的几种方法整理
参考: https://blog.csdn.net/secondlieutenant/article/details/79000265
- Python爬虫防封杀方法集合
Python爬虫防封杀方法集合 mrlevo520 2016.09.01 14:20* 阅读 2263喜欢 38 Python 2.7 IDE Pycharm 5.0.3 前言 ...
- python字符串操作实方法大合集
python字符串操作实方法大合集,包括了几乎所有常用的python字符串操作,如字符串的替换.删除.截取.复制.连接.比较.查找.分割等,需要的朋友可以参考下: #1.去空格及特殊符号 s.st ...
- 编程中遇到的Python错误和解决方法汇总整理
这篇文章主要介绍了自己编程中遇到的Python错误和解决方法汇总整理,本文收集整理了较多的案例,需要的朋友可以参考下 开个贴,用于记录平时经常碰到的Python的错误同时对导致错误的原因进行分析, ...
- Python的集合
1. Python的集合 1.1 集合的定义 在Python中, 集合set是基本数据类型的一种集合类型,它有可变集合(set())和不可变集合(frozenset)两种.Python中的集合set类 ...
随机推荐
- 【linux】之查看磁盘占用情况
查看整个硬盘使用情况: 1.df -h 2.du -bs xx 具体目录占用情况 3.查看当前目录大于100M的文件 find . -size +100M
- Ubuntu16.04主题美化
系统更新 sudo apt-get update sudo apt-get upgrade # 卸载libreOffice libreoffice是ubuntu自带的开源office软件,体验效果不如 ...
- C# 操作redis
下载 redis windows 版本 官网目前没有windows安装下载,下载地址为 https://github.com/MicrosoftArchive/redis/releases 直接点击安 ...
- 自动化接口测试(java)
githup地址:https://github.com/SailFan/autoTestMock 包结构: common包 ExtentTestNGIReporterListener.java 为测试 ...
- CSS画三角形图标
/* 等腰三角形(箭头朝上): */ #div1{ width: 0; height: 0; border-bottom: 100px solid cyan; border-left: 50px so ...
- 关于matlab2018a版本错误使用 svmclassify 分类器
当我们照常使用分类器函数svmclassify时,2018版的matlab会报出以下错误: 解决办法: 1,下载libsvm(一般下载最新版本就ok了)包,并将其添加至matlab的toolbox文件 ...
- Oracle参数Arraysize设置对于逻辑读的影响分析
说明: 当执行一条SQL查询的时候,为了获得满足的数据,查询在这个过程中完成解析,绑定,执行和提取数据等一系列步骤,这些步骤都是单独执行的,满足条件的数据行必须由数据库返回给应用:对于任何大小的结果集 ...
- Splunk 丰富数据方法
方法1: 查找 Step 1.创建CSV文件,首字段为索引字段(关联字段) 2.导入CSV文件,Settings, Lookups, Lookup tables files 3.配置Lookup de ...
- IntelliJ IDEA 工程Java文件上红色的无效符
IntelliJ IDEA 工程Java文件上红色的无效符(红色表示该类是不可编译文件) 1.查看Java.resources文件夹 如图所示,是因为没有配置 2.在Java文件夹点击右键找到Mark ...
- LeetCode 203. Remove Linked List Elements 移除链表元素 C++/Java
Remove all elements from a linked list of integers that have value val. Example: Input: ->->-& ...