集合 (set)
set 是一个无序不重复的元素集,集合跟字典是无序的,不支持索引
创建集合:
第一种方式:通过{ }创建
>>> num={1,2,3,4,3,3,1}
>>> num
{1, 2, 3, 4}
>>> type(num)
<class 'set'>
第二种方式:通过set()
>>> li=set(['aaa','bbb','aaa'])
>>> li
{'aaa', 'bbb'}
可以去除列表里的重复项但不能保证顺序:
>>> num=[4,3,2,1,2,2]
>>> num=list(set(num))
>>> num
[1, 2, 3, 4]
class set(object):
def add(self, *args, **kwargs): #添加,把传入的元素作为一个整个添加进去
>>> st.add('python')
>>> st
{'d', 'f', 'python', 'a', 'b', 'c'} def update(self, *args, **kwargs): # 更新,把传入的元素拆分然后传入集合
"""
>>> s1=set('boy')
>>> s1
{'b', 'y', 'o'}
>>> s1.update('python')
>>> s1
{'t', 'y', 'p', 'n', 'h', 'b', 'o'}
"""
pass def clear(self, *args, **kwargs): # 清空
>>> st.clear()
>>> st
set()
pass def copy(self, *args, **kwargs): # 拷贝 def difference(self, *args, **kwargs): #差集。在s1集合,不在s2集合的,操作后可以输出返回值
>>> s1=set(['aaa','bbb'])
>>> s2=set(['bbb','ccc'])
>>> s1.difference(s2)
{'aaa'} def difference_update(self, *args, **kwargs): #将s1更新为s1-s2的差集。没有返回值
>>> s1
{'aaa', 'bbb'}
>>> s2
{'bbb', 'ccc'}
>>> s1.difference_update(s2)
>>> s1
{'aaa'}
>>> s2
{'bbb', 'ccc'} def discard(self, *args, **kwargs): # 删除 def remove(self, *args, **kwargs): # 删除
#set.remove(obj)和set.discard(obj)的区别在于,当obj存在于set中时,都将其删除;但当obj不存在于set中时,remove()会报错,discard()不会。
def pop(self, *args, **kwargs): # 随机删除
>>> a=set('abcd')
>>> a.pop()
'b'
>>> a.pop()
'd' def intersection(self, *args, **kwargs): # 交集 s1 & s2
>>> s1=set(['aaa','bbb'])
>>> s2=set(['bbb','ccc'])
>>> d=s1.intersection(s2)
>>> print(d)
{'bbb'} def intersection_update(self, *args, **kwargs): # 交集 s1更新为这个值 def isdisjoint(self, *args, **kwargs): # 没有交集
>>> s1.isdisjoint(s2)
False def issubset(self, *args, **kwargs): # s1的每一个元素都在s2中
>>> s1=set('abc')
>>> s2=set('abcdef')
>>> s1.issubset(s2)
True
def issuperset(self, *args, **kwargs): # s2的每一个元素都在s1中
>>> s1.issuperset(s2)
False def symmetric_difference(self, *args, **kwargs): # s1,s2的对称差,有返回值
>>> s1=set(['aaa','bbb'])
>>> s2=set(['bbb','ccc'])
>>> d=s1.symmetric_difference(s2)
>>> print(d)
{'ccc', 'aaa'} def symmetric_difference_update(self, *args, **kwargs): # s1更新为s1,s2的对称差,没有返回值
>>> s1=set(['aaa','bbb'])
>>> s2=set(['bbb','ccc'])
>>> s1.symmetric_difference_update(s2)
>>> s1
{'aaa', 'ccc'} def union(self, *args, **kwargs): # 并集 s1 | s2
还有一种不可变的集合:frozenset
>>> s = frozenset([1,2,3,4])
>>> s.add(0)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
AttributeError: 'frozenset' object has no attribute 'add'
集合 (set)的更多相关文章
- java基础集合经典训练题
第一题:要求产生10个随机的字符串,每一个字符串互相不重复,每一个字符串中组成的字符(a-zA-Z0-9)也不相同,每个字符串长度为10; 分析:*1.看到这个题目,或许你脑海中会想到很多方法,比如判 ...
- .Net多线程编程—并发集合
并发集合 1 为什么使用并发集合? 原因主要有以下几点: System.Collections和System.Collections.Generic名称空间中所提供的经典列表.集合和数组都不是线程安全 ...
- 一起学 Java(三) 集合框架、数据结构、泛型
一.Java 集合框架 集合框架是一个用来代表和操纵集合的统一架构.所有的集合框架都包含如下内容: 接口:是代表集合的抽象数据类型.接口允许集合独立操纵其代表的细节.在面向对象的语言,接口通常形成一个 ...
- 编写高质量代码:改善Java程序的151个建议(第5章:数组和集合___建议75~78)
建议75:集合中的元素必须做到compareTo和equals同步 实现了Comparable接口的元素就可以排序,compareTo方法是Comparable接口要求必须实现的,它与equals方法 ...
- java基础_集合List与Set接口
List接口继承了Collection的方法 当然也有自己特有的方法向指定位置添加元素 add(索引,添加的元素); 移除指定索引的元素 remove(索引) 修改指定索引的元素 set ...
- Java基础Collection集合
1.Collection是所有集合的父类,在JDK1.5之后又加入了Iterable超级类(可以不用了解) 2.学习集合从Collection开始,所有集合都继承了他的方法 集合结构如图:
- 轻量级“集合”迭代器-Generator
Generator是PHP 5.5加入的新语言特性.但是,它似乎并没有被很多PHP开发者广泛采用.因此,在我们了解PHP 7对Generator的改进之前,我们先通过一个简单却显而易见的例子来了解下G ...
- Asp.net MVC 传递数据 从前台到后台,包括单个对象,多个对象,集合
今天为大家分享下 Asp.net MVC 将数据从前台传递到后台的几种方式. 环境:VS2013,MVC5.0框架 1.基本数据类型 我们常见有传递 int, string, bool, double ...
- 这些.NET开源项目你知道吗?.NET平台开源文档与报表处理组件集合(三)
在前2篇文章这些.NET开源项目你知道吗?让.NET开源来得更加猛烈些吧 和这些.NET开源项目你知道吗?让.NET开源来得更加猛烈些吧!(第二辑)中,大伙热情高涨.再次拿出自己的私货,在.NET平台 ...
- python 数据类型 --- 集合
1. 注意列表和集合的区别 set 列表表现形式: list_1 = [1,3,4]; 集合表现形式:set_1= set() list_1 = [1,2,3,4,23,4,2] print(lis ...
随机推荐
- Nginx 安装及配置
目录 概念 安装 配置文件 主要文件位置 注意点 Nginx运行 FAQ Q1:nginx: [error] open() "/usr/local/var/run/nginx.pid&quo ...
- FJUT Home_W的拆分序列(DP)题解
Problem Description Home 现在给你一个序列要求你将这个序列拆成恰好两个子序列.且使得两个子序列的抖动系数之和最大. 对于一个序列c1,c2,c3,……cm. 其抖动系数=|c1 ...
- 分布式事务框架&解决方案参考
两种开源解决方案框架介绍: https://blog.csdn.net/zyndev/article/details/79604395#_97 LCN: https://www.jianshu.com ...
- How to know the directory size in CENTOS 查看文件夹大小
Under any linux system, you want to use the command du. (Disk Usage) Common usage is : du -sh file(s ...
- 深度学习课程笔记(八)GAN 公式推导
深度学习课程笔记(八)GAN 公式推导 2018-07-10 16:15:07
- HDU 5607 graph(矩阵乘法)
题意 在一个 \(n\) 个节点 \(m\) 条边的有向图上随机游走,有 \(Q\) 个询问,每次给定一个起点 \(u\) 和步数 \(K\) ,每次回答最后停在每个节点的概率. \(1 \leq n ...
- getAttribute与getParameter的区别
1.getParameter得到的是字符串,其取值源于jsp页面,从jsp页面中接受一个存在的参数,多用于servlet中,用于判断业务的类型和跳转页面.如: request.getParameter ...
- 【OJ】字符串去重并并按原顺序打印出重复字符
ACM上一道简单的字符串题,从网上找了下类似的代码进行参考外加之个人思考,想到此好思路. 题目大意 任意输入一行字符串,检索重复出现的字符.将原字符串中的重复字符删除后按照原顺序输出,同时按照原顺序输 ...
- HDU 6215 Brute Force Sorting(链表)
http://acm.hdu.edu.cn/showproblem.php?pid=6215 题意:给出一个序列,对于每个数,它必须大于等于它前一个数,小于等于后一个数,如果不满足,就删去.然后继续去 ...
- [Python]IO密集型任务 VS 计算密集型任务
所谓IO密集型任务,是指磁盘IO.网络IO占主要的任务,计算量很小.比如请求网页.读写文件等.当然我们在Python中可以利用sleep达到IO密集型任务的目的. 所谓计算密集型任务,是指CPU计算占 ...