详解python的集合set的函数
目录
- 常用
- 查询
- 增加
- 删除
- 交、并、补、对称差
- 交集
- 并集
- 补集
- 对称差
- 其他
- 总结
s={ x1,x2,x3.....};
集合有自动去重的功能,而且可以进行交并补运算,而且集合是无序的,每次打印的结果不一样,故不可以用元素下标进行取值。因无法取值,故无法对特定的值进行修改。但是可以进行删除操作。
s=set();表示创建一个空的集合。注意:s={}表示创建一个空的字典。
常用
查询
x in s,s为一个集合,返回bool类型,判断x是否在集合s中。
增加
s.add(“x”);将“x”添加到集合s中。
删除
s.pop()
;随机删除集合s中的一个元素。
s.remove(“x”)
;删除集合s中的元素“x”,若无“x”则报错。
s.discard(“x”)
;删除集合s中的元素“x”,若无“x”不报错。
s.clear()
;将集合s清空,清空后s=set()。
交、并、补、对称差
交集
s=s1&s2
;s=s1.intersection(s2)
,s=set.intersection(s1,s2)
;得到集合s为集合s1和集合s2的交集。
并集
s=s1|s2
;s=s1.unoin(s2)
,s=set.union(s1,s2)
;得到集合s为集合s1和集合s2的并集。
补集
s=s1-s2
;s=s1.difference(s2)
,s=set.difference(s1,s2)
;得到集合s为在集合s1中但不在集合s2中的元素。
对称差
s=s1^s2
;s=s1.symmetric_difference(s2)
,s=set.symmetric_difference(s1,s2)
;得到集合s为仅在集合s1和仅在集合s2中的元素之和。
其他
s1=s.copy()
;将集合s的数据复制给集合s1,s和s1的地址不同,互不影响。(若用s1=s,则s1的数据与s相同且地址相同,对s做修改等于对s1做修改)
s.difference_update(s1,s2)
;将s-s1-s2的结果(补集)赋值给s。
s.intersection_update(s1,s2)
;将s&s1&s2的结果(交集)赋值给s。
s.isdisjoint(s1)
;如果s与s1的交集为空,则返回True,否则返回False。
s.issubset(s1)
;若s为s1的子集,则返回True。
s.issuperset(s1)
;若s1为s的子集,则返回True。
s.symmetric_difference_update(s1)
;括号内只能有一个参数,将s^s1的结果(对称差)赋值给s。
s.update(s1,s2)
;将s|s1|s2的结果(并集)赋值给s 。
总结
本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注我们的更多内容!
相关推荐
-
python set内置函数的具体使用
set集合 无序可变 由不同元素组成 其元素必须为可哈希的类型(通俗来说不可变类型) 集合的两种定义方式 使用{} Eg:{1,2,3,4,5} 使用set(可迭代类型)函数 Eg:set("hello") * 使用frozenset()函数创建不可变集合 基本函数 s = set("hello") """ 添加一个元素到集合中 """ s.add('b') """ 使用可迭代
-
python中set()函数简介及实例解析
set函数也是python内置函数的其中一个,属于比较基础的函数.其具体介绍和使用方法,下面进行介绍. set() 函数创建一个无序不重复元素集,可进行关系测试,删除重复数据,还可以计算交集.差集.并集等. set,接收一个list作为参数 list1=[1,2,3,4] s=set(list1) print(s) #逐个遍历 for i in s: print(i) 输出: set([1, 2, 3, 4]) 1 2 3 4 使用add(key)往集合中添加元素,重复的元素自动过滤 list1
-
详解Python3 中hasattr()、getattr()、setattr()、delattr()函数及示例代码数
hasattr()函数 hasattr()函数用于判断是否包含对应的属性 语法: hasattr(object,name) 参数: object--对象 name--字符串,属性名 返回值: 如果对象有该属性返回True,否则返回False 示例: class People: country='China' def __init__(self,name): self.name=name def people_info(self): print('%s is xxx' %(self.name))
-
Python set常用操作函数集锦
定义 set是一个无序且不重复的元素集合. 集合对象是一组无序排列的可哈希的值,集合成员可以做字典中的键.集合支持用in和not in操作符检查成员,由len()内建函数得到集合的基数(大小), 用 for 循环迭代集合的成员.但是因为集合本身是无序的,不可以为集合创建索引或执行切片(slice)操作,也没有键(keys)可用来获取集合中元素的值. set和dict一样,只是没有value,相当于dict的key集合,由于dict的key是不重复的,且key是不可变对象因此set也有如下特性:
-
Python 利用内置set函数对字符串和列表进行去重的方法
如下所示: # coding:utf8 __author__ = 'libingxian' __date = "20170415" # 由于数据类型set本身具有无序,唯一值的特性,可以用内置函数set对字符串和列表进行去重,挺方便的 str = "asdfasdlklfgklgjsdfjkjl" se = set(str) print se li = [1,"2",1,"2","abc","12
-
详解python的集合set的函数
目录 常用 查询 增加 删除 交.并.补.对称差 交集 并集 补集 对称差 其他 总结 s={ x1,x2,x3.....}: 集合有自动去重的功能,而且可以进行交并补运算,而且集合是无序的,每次打印的结果不一样,故不可以用元素下标进行取值.因无法取值,故无法对特定的值进行修改.但是可以进行删除操作. s=set():表示创建一个空的集合.注意:s={}表示创建一个空的字典. 常用 查询 x in s,s为一个集合,返回bool类型,判断x是否在集合s中. 增加 s.add(“x”):将“x”添
-
详解python编程slice与indices函数用法示例
一般来说,内置的slice()函数会创建一个切片对象,可以用在任何允许进行切片操作的地方. 下面是slice的简介: # slice 两种用法 class slice(stop) class slice(start, stop[, step]) 返回一个表示由 range(start, stop, step) 所指定索引集的 slice对象. 其中 start 和 step 参数默认为 None. 切片对象具有仅会返回对应参数值(或其默认值)的只读数据属性 start, stop 和 step.
-
详解Python函数式编程—高阶函数
函数式编程就是一种抽象程度很高的编程范式,纯粹的函数式编程语言编写的函数没有变量,因此,任意一个函数,只要输入是确定的,输出就是确定的,这种纯函数我们称之为没有副作用.而允许使用变量的程序设计语言,由于函数内部的变量状态不确定,同样的输入,可能得到不同的输出,因此,这种函数是有副作用的. 函数式编程的一个特点就是,允许把函数本身作为参数传入另一个函数,还允许返回一个函数! Python对函数式编程提供部分支持.由于Python允许使用变量,因此,Python不是纯函数式编程语言. 高阶函数 变量
-
详解Python的hasattr() getattr() setattr() 函数使用方法
hasattr(object, name) 判断一个对象里面是否有name属性或者name方法,返回BOOL值,有name特性返回True, 否则返回False. 需要注意的是name要用括号括起来 >>> class test(): ... name="xiaohua" ... def run(self): ... return "HelloWord" ... >>> t=test() >>> hasattr(
-
详解Python中的format格式化函数的使用方法
format函数实现字符串格式化的功能 基本语法为: 通过 : 和 {} 来控制字符串的操作 一.对字符串进行操作 1. 不设置指定位置,按默认顺序插入 ①当参数个数等于{}个数的时候 str_1 = "小明{}小美,可是小美{}小明".format("喜欢", "不喜欢") print(str_1) 运行结果: ②当参数个数大于{}个数的时候 str_1 = "小明{}小美,可是小美{}小明".format("喜欢
-
详解Python map函数及Python map()函数的用法
python map函数 map()函数 map()是 Python 内置的高阶函数,它接收一个函数 f 和一个 list,并通过把函数 f 依次作用在 list 的每个元素上,得到一个新的 list 并返回. 例如,对于list [1, 2, 3, 4, 5, 6, 7, 8, 9] 如果希望把list的每个元素都作平方,就可以用map()函数: 因此,我们只需要传入函数f(x)=x*x,就可以利用map()函数完成这个计算: def f(x): return x*x print map(f,
-
详解Python 函数参数的拆解
本文为阅读 <Python Tricks: The Book>一书的 3.5 Function Argument Unpacking 的笔记与扩充理解.函数参数拆解是定义可变参数(VarArgs) *args 和 **kwargs 的反向特性. *args 和 **kwars 是函数可定义一个形参来接收传入的不定数量的实参. 而这里的函数参数拆解是形参定义多个,在调用时只传入一个集合类型对象(带上 * 或 ** 前缀),如 list, tuple, dict, 甚至是 generator, 然
-
详解python函数传参传递dict/list/set等类型的问题
传参时传递可变对象,实际上传的是指向内存地址的指针/引用 这个标题是我的结论,也是我在做项目过程查到的.学过C的都知道,函数传参可以传值,也可以传指针.指针的好处此处不再赘述. 先上代码看看效果: def trans(var): return var source = {1: 1} dist = trans(source) source[2] = 2 print(source) print(dist) 运行结果: {1: 1, 2:2} {1: 1, 2:2} 可以看到改变了source时,di
-
详解Python中enumerate函数的使用
Python 的 enumerate() 函数就像是一个神秘的黑箱,你无法简单地用一句话来概括这个函数的作用与用法. enumerate() 函数属于非常有用的高级用法,而对于这一点,很多初学者甚至中级学者都没有意识到.这个函数的基本应用就是用来遍历一个集合对象,它在遍历的同时还可以得到当前元素的索引位置. 我们看一个例子: names = ["Alice","Bob","Carl"] for index,value in enumerate(n
-
详解Python函数可变参数定义及其参数传递方式
Python函数可变参数定义及其参数传递方式详解 python中 函数不定参数的定义形式如下 1. func(*args) 传入的参数为以元组形式存在args中,如: def func(*args): print args >>> func(1,2,3) (1, 2, 3) >>> func(*[1,2,3]) #这个方式可以直接将一个列表的所有元素当作不定参数 传入(1, 2, 3) 2.func( **kwargs) 传入的参数为以字典形式存在args中,如: d
随机推荐
- Linux 中fork的执行的实例详解
- jQuery语法高亮插件支持各种程序源代码语法着色加亮
- 本地存储localStorage用法详解
- Android开发中如何解决Fragment +Viewpager滑动页面重复加载的问题
- Python max内置函数详细介绍
- CodeIgniter中使用Smarty3基本配置
- python网络编程调用recv函数完整接收数据的三种方法
- Python实现运行其他程序的四种方式实例分析
- linux中常用脚本和函数分享
- jQuery实现两列等高并自适应高度
- 卡巴斯基6.0设置技巧全接触之图文教程
- Java使用ByteArrayOutputStream 和 ByteArrayInputStream 避免重复读取配置文件的方法
- java 字符串反转的实例详解
- web前端页面生成exe可执行文件的方法
- 深入了解JavaScript 私有化
- 易语言取主机名命令使用讲解
- re模块的正则匹配的表达式详解
- laravel清除视图缓存的代码
- nodejs实现的简单web服务器功能示例
- webpack常用配置总览(小结)