python集合操作方法详解
前言
说集合之前,我们先说一个小例子,假设某公司有五个人喜欢打篮球,五个人喜欢打游戏,问即打游戏有打篮球的人都有哪些?
play_basketball = ['a','b','c','d','e'] play_game = ['a','b','c','f','g'] both_play=[] for name in play_basketball: if name in play_game: both_play.append(name) print(both_play) 结果: ['a', 'b', 'c']
在不了解集合之前我们肯定以上面的方法解决问题,但是学了集合之后,我们就有更简单的方法了,是什么呢?让我们慢慢了解。
集合set
集合用于包含一组无序的对象。与列表和元组不同,集合是无序的,也无法通过数字进行索引。此外,集合中的元素不能重复。set和dict一样,只是没有value,相当于dict的key集合,由于dict的key是不重复的,且key是不可变对象因此set也有如下特性:
- 不重复,(互异性),也就是说集合是天生去重的
- 元素为不可变对象,(确定性,元素必须可hash)
- 集合的元素没有先后之分,(无序性)
首先笼统的讲一下python3.x集合的内置函数有17个,分别如下:
序号 | 函数 | 描述 |
1 |
add(self, *args, **kwargs) |
是把要传入的元素做为一个整个添加到集合中 |
2 |
clear(self, *args, **kwargs) |
清空集合里面的所有元素 |
3 |
copy(self, *args, **kwargs) |
复制集合里面的所有元素 ,返回一个浅复制 |
4 |
difference(self, *args, **kwargs) |
求两个集合里面的不同的元素 ,又称差 |
5 |
difference_update(self, *args, **kwargs) |
返回删除了 set “集合2”中含有的元素后的 set “集合1” |
6 |
discard(self, *args, **kwargs) |
如果在 set “集合”中存在元素 x, 则删除 |
7 |
intersection(self, *args, **kwargs) |
求两个集合里面相同的元素,又称并 , 返回只保留含有 set “集合2”中元素的 set “集合1” |
8 |
intersection_update(self, *args, **kwargs) |
,
返回只保留含有 set “集合2”中元素的 set “集合1” ,并更新自己 |
9 |
isdisjoint(self, *args, **kwargs) |
判断两个集合是不是不相交,并返回 |
10 |
issubset(self, *args, **kwargs) |
判断集合是不是包含其他集合,等同于a>=b |
11 |
issuperset(self, *args, **kwargs) |
判断集合是不是被其他集合包含,等同于a<=b |
12 |
pop(self, *args, **kwargs) |
删除并且返回 set “集合”中的一个不确定的元素, 如果为空则引发 KeyError |
13 |
remove(self, *args, **kwargs) |
从 set “集合”中删除元素 , 如果不存在则引发 KeyError |
14 |
symmetric_difference(self, *args, **kwargs) |
返回一个新的 set 包含 外面 和 里面 中不重复的元素 也就是两个集合不重复的元素 |
15 |
symmetric_difference_update(self, *args, **kwargs) |
返回含有 set “里面”或者 set “外面”中有而不是两者都有的元素的 set “外面” |
16 |
union(self, *args, **kwargs) |
把两个集合连接起来,又称并 |
17 |
update(self, *args, **kwargs) |
可以在集合里面添加多项 |
1,定义集合
#第一种方法 nums = [1,2,3,4,5,6,7] num_set = set(nums) print(num_set) 结果: {1, 2, 3, 4, 5, 6, 7}<br><br>#第二种方法<br>num_set ={1,2,3,4,5,6,7}
2,增(更新)
set.add()
set.update([])
nums = {1,2,3,4,5,6,7} #set.add()增加只能增加一个,不能增加多个值 # nums.add(8) # print(nums) #set.update()可以增加一个字符串,可以增加多个值 # nums.update([8]) # print(nums) # nums.update('8') # print(nums) nums.update([8,9,10]) print(nums)
3,删
set1.remove(1)
nums = {1,2,3,4,5,6,7} nums.remove(7) print(nums) 结果: {1, 2, 3, 4, 5, 6}
4,查:无法通过下标索引
5,改:不可变类型无法修改元素
6,交( &)
nums1 ={1, 2, 3, 4, 5, 6} nums2 ={1, 2, 3, 4, 5, 10,7,8,9} #交的方式一:& a = nums1&nums2 print(a) #并的方式二:intersaction b = nums1.intersection(nums2) print(b) 结果: {1, 2, 3, 4, 5} {1, 2, 3, 4, 5}
7,并(|)
nums1 ={1, 2, 3, 4, 5, 6} nums2 ={1, 2, 3, 4, 5, 10,7,8,9} #并的方式一:| a = nums1|nums2 print(a) #并的方式二:uniom b = nums1.union(nums2) print(b) 结果: {1, 2, 3, 4, 5, 6, 7, 8, 9, 10} {1, 2, 3, 4, 5, 6, 7, 8, 9, 10}
8,差(-)
nums1 ={1, 2, 3, 4, 5, 6} nums2 ={1, 2, 3, 4, 5, 10,7,8,9} #差的方式一:- a1 = nums1-nums2 print(a1) a2 = nums2-nums1 print(a2) #差的方式二:difference b1 = nums1.difference(nums2) print(b1) b2 = nums2.difference(nums1) print(b2) 结果: {6} {8, 9, 10, 7} {6} {8, 9, 10, 7}
9,对称差集(^)
nums1 ={1, 2, 3, 4, 5, 6} nums2 ={1, 2, 3, 4, 5, 10,7,8,9} #对称差集表示方法一:^ a1 = nums1^nums2 print(a1) #对称差集表示方法二:symmetric_difference a2 = nums2.symmetric_difference(nums1) print(a2) 结果: {6, 7, 8, 9, 10} {6, 7, 8, 9, 10}
10,集合转换
se = set(range(4)) li = list(se) tu = tuple(se) st = str(se) print(li,type(li)) print(tu,type(tu)) print(st,type(st)) 结果: [0, 1, 2, 3] <class 'list'> (0, 1, 2, 3) <class 'tuple'> {0, 1, 2, 3} <class 'str'>
补充:frozenset
冰冻集合,是一种特殊的集合类型,也是集合(集合是列表的话,冰冻集合就是元组)
下面创建冰冻集合(一般不会创建空的冰冻集合)
同时下面包含函数的补充
#创建带数据的冰冻集合 info = frozenset(('xuexi','gongzuo','kaoyan','xiuxi')) print(info,type(info)) #成员监测 result = 'gongzuo' in info print(result) #遍历冰冻集合 for i in info: print(i) #集合推导式(无法得到冰冻集合,可以得到集合,列表,元组,字典类型) result = {i for i in info} print(result,type(result)) #函数 #冰冻集合可以使用集合的函数(不修改集合本身的函数都可以使用) info = frozenset(('xuexi','gongzuo','kaoyan','xiuxi')) #copy() result = info.copy() print(result) #集合操作 交集,并集,差集,对称差集等 不修改冰冻集合本身就能使用:冰冻集合的操作结果都是冰冻集合 info = frozenset(('xuexi','gongzuo','kaoyan','xiuxi')) info2 = {'xuexi','gongzuo','kaoyan','xiuxi'} #冰冻集合操作 result = info.union(info2) print(result) #普通集合操作(冰冻集合是参考集合) result = info2.union(info) print(result)
python集合操作方法详解的更多相关文章
- python 集合操作方法详解
说集合之前,我们先说一个小例子,假设某公司有五个人喜欢打篮球,五个人喜欢打游戏,问即打游戏有打篮球 的人都有哪些? play_basketball = ['a','b','c','d','e'] pl ...
- python 字符串操作方法详解
字符串序列用于表示和存储文本,python中字符串是不可变对象.字符串是一个有序的字符的集合,用于存储和表示基本的文本信息,一对单,双或三引号中间包含的内容称之为字符串.其中三引号可以由多行组成,编写 ...
- python 字典操作方法详解
字典是一种通过名字或者关键字引用的得数据结构,key 类型需要时被哈希,其键可以是数字.字符串.元组,这种结构类型也称之为映射.字典类型是Python中唯一內建的映射类型. 注意,浮点数比较很不精确, ...
- python 列表操作方法详解
列表是Python中最基本的数据结构,列表是最常用的Python数据类型,列表是一个数据的集合,集合内可以放任何数据类型,可对集合方便的增删改查操作.Python已经内置确定序列的长度以及确定最大和最 ...
- python字符串操作方法详解
字符串 字符串序列用于表示和存储文本,python中字符串是不可变对象.字符串是一个有序的字符的集合,用于存储和表示基本的文本信息,一对单,双或三引号中间包含的内容称之为字符串.其中三引号可以由多 ...
- python列表操作方法详解
列表 列表是Python中最基本的数据结构,列表是最常用的Python数据类型,列表是一个数据的集合,集合内可以放任何数据类型,可对集合方便的增删改查操作.Python已经内置确定序列的长度以及确 ...
- python字典操作方法详解
前言 字典是一种通过名字或者关键字引用的得数据结构,key 类型需要时被哈希,其键可以是数字.字符串.元组,这种结构类型也称之为映射.字典类型是Python中唯一內建的映射类型. 注意,浮点数比较很不 ...
- Python 列表(List)操作方法详解
Python 列表(List)操作方法详解 这篇文章主要介绍了Python中列表(List)的详解操作方法,包含创建.访问.更新.删除.其它操作等,需要的朋友可以参考下 列表是Python中最基本 ...
- Python 字符串方法详解
Python 字符串方法详解 本文最初发表于赖勇浩(恋花蝶)的博客(http://blog.csdn.net/lanphaday),如蒙转载,敬请保留全文完整,切勿去除本声明和作者信息. ...
随机推荐
- FreeRTOS学习笔记5:队列
为通信而准备 1.任务存储存储缓冲机制:先进先出 FIFO 后进先出 LIFO (ucOS消息队列采用的是引用传递,传递的都是指针.采用引用的话,内容必须一致保持可见性,即消息内容必须有效.1.不能传 ...
- python evel()的用法
老生常谈部分: eval(expression[, globals[, locals]]) expression -- 表达式. globals -- 变量作用域,全局命名空间,如果被提供,则必须是一 ...
- [蓝桥杯][基础训练]FJ的字符串
Description FJ在沙盘上写了这样一些字符串: A1 = “A” A2 = “ABA” A3 = “ABACABA” A4 = “ABACABADABACABA” … … 你能找出其中的规律 ...
- linux shell 正则表达式详解
正则 1. 普通正则表达式 2. 扩展正则表达式 普通正则表达式 . 任意一个字符 * 前面一个字符出现0次或者多次 [abc] 中括号内任意一个字符 [^abc] 非括号内任意一个字符 [0-9] ...
- nodejs的req取参req.body,req.params,req.query
1/req.query: Get:/domo?name=ximiximi&blog=https://home.cnblogs.com/u/ximiximi-blog/ app.get('/do ...
- C语言对两个浮点数进行比较的方法
C语言对两个浮点数进行比较: C语言用"=="来比较两个浮点数,返回值完全是不确定的. 因此只能定义一个精度来确定是否相等: if(fabs(a-b) < 0.000000 ...
- linux 磁盘100% 清理
df -h 查看磁盘使用有一个vdb满了 df -i 查看inode 使用率 显示文件大小: du -sh /* du参数: -a : 列出所有的文件与目录容量,因为默认仅统计目录下面的文件量而 ...
- 算法刷题--回溯算法与N皇后
所谓回溯算法,在笔者看来就是一种直接地思想----假设需要很多步操作才能求得最终的解,每一步操作又有很多种选择,那么我们就直接选择其中一种并依次深入下去.直到求得最终的结果,或是遇到明细的错误,回溯到 ...
- 6_8 树(UVa548)<从中序和后序恢复二叉树>
你的任务是找出一棵二叉树中最小路径上终端节点(树叶,leaf node)的值.所谓路径乃指从根节点(root)旅行到任一终端节点.路径的值为所经过的节点的值的和(包含根节点及终端节点).而最小路径就是 ...
- Java方法升级
1. 方法格式 package cn.itcast.day04.demo02; /* 方法其实就是若干语句的功能集合. 方法好比是一个工厂. 蒙牛工厂 原料:奶牛.饲料.水 产出物:奶制品 钢铁工厂 ...