Set集合:是Python的一个基本数据类型。一般不是很常用。Set中的元素是不重复的,无序的,里面的元素必须是可hash的(int,str,tuple,bool)。我们可以这样来计Set就是dict类型的数据但是不保存value,只保存key,set也用{}表示。

注意:set集合中的元素必须是可hash的,但是set本身是不可hash的,set是可变的。【即为:set内部不能有set】

#定义一个set集合
s = {'a'}
print(s)
print(type(s)) #实例化
s1 = set()#声明一个空set集合 #s3 = {123,[12,34,4]} #报错 TypeError: unhashable type: 'list'
#s3 = {123,(12,34,4)} #正常
#s4 = {123,{12,34,4}} #报错

  执行结果:

{'a'}
<class 'set'>

  set集合中的元素是不重复的,且无序的

#set中的元素是不重复的,且无序的
s2 = {'abc','12','bd','abc',True,False}
print(s2) #去重 {False, True, '12', 'abc', 'bd'}

set中的常用操作:

  1)增加

>>> s = {"张三","李四","王五"}
>>> s.add("赵六") #重复的内容不会被添加到set集合中
>>> s
{'王五', '李四', '赵六', '张三'}
>>> s.update("薛七") #迭代更新 即把“薛”和“七”分别加入set集合
>>> s
{'王五', '薛', '七', '李四', '赵六', '张三'}

  2)删除

>>> s.pop()#随机删除一个元素
'王五'
>>> s.remove("张三")#直接删除元素,如果不存在这个元素,删除会报错
>>> s
{'薛', '七', '李四', '赵六'}
>>> s.clear()#清空set集合需要注意的是set集合如果是空的,打印出来是set(),因为要和dict区分
>>> s
set()

  3)修改

  set集合中的数据没有索引,也没用办法去定位一个元素,所以没有办法进行直接修改。我们可以采用先删除后添加的方式来完成修改操作。

>>> s = {"张三","李四","王五"}
>>> s.remove("张三")
>>> s.add("赵六")
>>> s
{'王五', '李四', '赵六'}

  4)查询

  set是一个可迭代对象,可以进行for循环

>>> for el in s:
print(el) 王五
李四
赵六

  5)常用操作

#求交集
>>> s1 = {"张三","李四","王五"}
>>> s2 = {"王五","赵六","薛七"}
>>> s1 & s2
{'王五'}
>>> s1.intersection(s2)
{'王五'} #求并集
>>> s1 | s2
{'王五', '薛七', '李四', '赵六', '张三'}
>>> s1.union(s2)
{'王五', '薛七', '李四', '赵六', '张三'} #求差集
>>> s1 - s2
{'李四', '张三'}
>>> s1.difference(s2)
{'李四', '张三'} #求反交集 集两个set集合中单独存在的数据元素
>>> s1 ^ s2
{'张三', '李四', '赵六', '薛七'}
>>> s1.symmetric_difference(s2)
{'张三', '李四', '赵六', '薛七'} #子集
>>> s3 = {"张三","李四"}
>>> s4 = {"张三","李四","王五"}
>>> s1 < s2
False
>>> s3 < s4
True #超集
>>> s1 > s2
False
>>> s3.issuperset(s4)
False
>>>

  

python基础知识 -- set集合的更多相关文章

  1. Python基础知识:集合

    1.集合(set)是一个存放在中括号内的无序,不重复的序列.例如:set = {'1','12','25'} 2.创建集合的两种方法: set = {1,2,3} 中括号直接创建 set = {[1, ...

  2. python基础知识笔记-集合

    集合使用花括号将元素之间用逗号隔开即可.集合的输出里不会出现相同的元素.集合中有并集.交集.差集等,以下为一些简单的表达: def main(): list1=[1,1,2,2,3,3] print( ...

  3. python基础知识(集合)

    集合 可变集合set()/不可变集合frozenset() {}  大写的拉丁字母 用于保存不重复元素.无序不能通过索引来获取 集合的创建 空集合 使用set()函数 变量名 = set() 集合的添 ...

  4. python爬虫主要就是五个模块:爬虫启动入口模块,URL管理器存放已经爬虫的URL和待爬虫URL列表,html下载器,html解析器,html输出器 同时可以掌握到urllib2的使用、bs4(BeautifulSoup)页面解析器、re正则表达式、urlparse、python基础知识回顾(set集合操作)等相关内容。

    本次python爬虫百步百科,里面详细分析了爬虫的步骤,对每一步代码都有详细的注释说明,可通过本案例掌握python爬虫的特点: 1.爬虫调度入口(crawler_main.py) # coding: ...

  5. Python基础知识(六)------小数据池,集合,深浅拷贝

    Python基础知识(六)------小数据池,集合,深浅拷贝 一丶小数据池 什么是小数据池: ​ 小数据池就是python中一种提高效率的方式,固定数据类型使用同一个内存地址 代码块 : ​ 一个文 ...

  6. Python开发【第二篇】:Python基础知识

    Python基础知识 一.初识基本数据类型 类型: int(整型) 在32位机器上,整数的位数为32位,取值范围为-2**31-2**31-1,即-2147483648-2147483647 在64位 ...

  7. python 基础知识(一)

    python 基础知识(一) 一.python发展介绍 Python的创始人为Guido van Rossum.1989年圣诞节期间,在阿姆斯特丹,Guido为了打发圣诞节的无趣,决心开发一个新的脚本 ...

  8. python 爬虫与数据可视化--python基础知识

    摘要:偶然机会接触到python语音,感觉语法简单.功能强大,刚好朋友分享了一个网课<python 爬虫与数据可视化>,于是在工作与闲暇时间学习起来,并做如下课程笔记整理,整体大概分为4个 ...

  9. python基础知识小结-运维笔记

    接触python已有一段时间了,下面针对python基础知识的使用做一完整梳理:1)避免‘\n’等特殊字符的两种方式: a)利用转义字符‘\’ b)利用原始字符‘r’ print r'c:\now' ...

随机推荐

  1. Android使用Fragment来实现TabHost的功能

    http://www.cnblogs.com/tiantianbyconan/p/3360938.html 好了,到此为止,我们已经用Fragment实现了类似TabHost的功能了,下面来看下各个F ...

  2. linux下使用第三方商店安装应用

    安装 snap store 进行下载,相当与第三方应用商店,但是往往比某一个官方软件源里面的应用要丰富或更实用 到 snap docs 中选择你的 linux 版本进入安装文档,根据指示一步一步安装即 ...

  3. [EffectiveC++]item40:明智而审慎地使用多重继承

  4. 什么是SWP文件?能否删除swp文件?

    SWP意思就是交换文件..SWP是各种操作系统(Windows或Linux)使用的交换文件的文件扩展名. 可以安全地清理SWP文件以释放磁盘空间. 要清理SWP文件,请按照以下步骤操作: 运行WinU ...

  5. python接口测试-项目实践(三)数据的处理示例

    三 数据处理 枚举值的转换.如接口返回1-5,需转成对应的中文. typecap = findinfo_from_api(result, 'TypeCap') dictcap = {': '微盘'} ...

  6. IOS CoreData的(增删查改)

    (1).CoreDataa>什么是CoreDatab>CoreData增删改查 "什么时候使用COredata 什么时候使用FMDatabases"CoreData 在 ...

  7. Linux下elk安装配置

    安装jdkJDK版本大于1.8 elk下载地址:https://www.elastic.co/products注意:elk三个版本都要保持一致. rpm -ivh elasticsearch-5.4. ...

  8. csu 1965

    Description You are a boss who has N employers. One day, you have a message and you want to tell it ...

  9. luogu P3787 冰精冻西瓜

    嘟嘟嘟 好题,好题…… 看这个修改和询问,就知道要么是求完dfs序后线段树维护,要么是树剖.又因为这道题都是子树的操作,没有链上的,所以线段树就够了. 然而重点不是这个.这道题最麻烦的是线段树push ...

  10. 效率对比:各种语言构造100W个时间对象

    原本是用perl写了一个通过给定的时间范围来筛选一个比较大的日志文件.但是测试发现筛选130W行日志需要2分多钟,对其中几个低效率函数单独进行了效率测试,发现构造100W个时间对象所花时间也是个大户. ...