1.概念

(1)不同元素组成

例:

s = {1,2,3,4,4,4,4,4,4}
print(s)
运行结果:
{1, 2, 3, 4}
因为是不同元素组成,因此去重了

(2)无序

例:

s = {"xiao","xing","ceshi","admin"}
print(s)
运行结果每次显示的顺序不一样,代表是无序的

(3)集合元素必须是不可变类型

例:

s = {[123,456],789}
print(s)
运行结果:
TypeError: unhashable type: 'list'
因为列表是可变,所以会报错

2.集合的方法

1.add   添加
s = {123,456,789}
s.add(2)
print(s)
运行结果:
{456, 2, 123, 789}

2.clear 清空
s = {123,456,789}
s.clear()
print(s)
运行结果:
set()

3.copy 复制
s = {123,456,789}
s1 = s.copy()
print(s1)
运行结果:
{123,456,789}

4.pop 删除(无序删除,随机删除,不可指定删除)
s = {123,456,789}
s.pop()
print(s)
运行结果:
{123, 789}

5.remove 删除(可指定删除,元素不存在时会报错)
s = {123,456,789}
s.remove(789)
print(s)
运行结果:
{456, 123}
6.discard  删除(可指定删除,元素不存在时不会报错)

3.集合的关系运算,交,差并集操作

(1)求交集(需求在列表中找出既学python又学linux的人)

python_1 = ["xiao","xing","ly"]
linux_1 = ["ly","xing"]
python_and_linux =[]
for p_name in python_1:
if p_name in linux_1:
python_and_linux.append(p_name)
print(python_and_linux)
运行结果:
['xing', 'ly']

学过集合后的操作
python_1 = ["xiao","xing","ly"]
linux_1 = ["ly","xing"]
p_s =set(python_1)
#set函数相当于,for循环遍历python_1这个列表,然后把列表中的元素依次放到集合当中,如果是重复就去除,最终生成p_s集合是无序的
l_s = set(linux_1)
print(p_s,l_s)
print(p_s.intersection(l_s))
print(p_s&l_s)
运行结果:

{'xing', 'xiao', 'ly'} {'xing', 'ly'}
{'xing', 'ly'}
{'xing', 'ly'}

(2)求并集

python_1 = ["xiao","xing","ly"]
linux_1 = ["ly","xing","zx"]
print(p_s.union(l_s))
或者
print(p_s|l_s)
运行结果:
{'zx', 'ly', 'xing', 'xiao'}

(3)求差集

python_1 = ["xiao","xing","ly"]
linux_1 = ["ly","xing","zx"]
print(p_s.difference(l_s))
或者
print('差集',p_s-l_s)
运行结果:

{'xiao'}
   差集 {'xiao'}

(4)求交叉补集

python_1 = ["xiao","xing","ly"]
linux_1 = ["ly","xing","zx"]
print(p_s.symmetric_difference(l_s))
运行结果:
{'xiao', 'zx'}

(5)求完叉集再赋值给原来的值

difference_update
python_1 = ["xiao","xing","ly"]
linux_1 = ["ly","xing","zx"]
p_s =set(python_1)
l_s = set(linux_1)
#p_s = p_s - l_s
#print(p_s)
p_s.difference_update(l_s)
print(p_s)
运行结果:
{'xiao'}
difference_update先求差集,再将差集赋值给p_s

(6)判断两个集合是否有交集,无则返回true

s = {1,2,3}
s1 = {4,5}
print(s.isdisjoint(s1))
运行结果:
True

(7)判断是否为其子集

s1 = {1,2}
s2 = {1,2,3}
print(s1.issubset(s2))
运行结果:
true

(8)判断是否为其父集

s1 = {1,2}
s2 = {1,2,3}
print(s2.issuperset(s1))
运行结果:
true

(9)更新多个值

s1 = {1,2}
s2 = {1,2,3}
s1.update(s2)
print(s1)
运行结果:
{1, 2, 3}

(10)定义不可变集合

s = frozenset('hello')
print(s)
运行结果:
frozenset({'h', 'o', 'e', 'l'})
再s.的时候发现无法添加,修改,删除操作

(4)求完叉集再赋值给原来的值

Python学习【第6篇】:集合的定义和基本方法的更多相关文章

  1. Python学习笔记基础篇——总览

    Python初识与简介[开篇] Python学习笔记——基础篇[第一周]——变量与赋值.用户交互.条件判断.循环控制.数据类型.文本操作 Python学习笔记——基础篇[第二周]——解释器.字符串.列 ...

  2. python学习博客地址集合。。。

    python学习博客地址集合...   老师讲课博客目录 http://www.bootcdn.cn/bootstrap/  bootstrap cdn在线地址 http://www.cnblogs. ...

  3. python学习6—数据类型之集合与字符串格式化

    python学习6—数据类型之集合与字符串格式化 1. 使用id()可以查看一个变量的内存地址: name = 'alex' id(name) 2. 进制转换 十进制转换为二进制等: a = 10 # ...

  4. Python 学习 第十篇 CMDB用户权限管理

    Python 学习 第十篇 CMDB用户权限管理 2016-10-10 16:29:17 标签: python 版权声明:原创作品,谢绝转载!否则将追究法律责任. 不管是什么系统,用户权限都是至关重要 ...

  5. Python学习笔记进阶篇——总览

    Python学习笔记——进阶篇[第八周]———进程.线程.协程篇(Socket编程进阶&多线程.多进程) Python学习笔记——进阶篇[第八周]———进程.线程.协程篇(异常处理) Pyth ...

  6. Python学习笔记——基础篇【第六周】——面向对象

    Python之路,Day6 - 面向对象学习 本节内容:   面向对象编程介绍 为什么要用面向对象进行开发? 面向对象的特性:封装.继承.多态 类.方法.       同时可参考链接: http:// ...

  7. Python 学习笔记---基础篇

    1. 简单测试局域网中的电脑是否连通.这些电脑的ip范围从192.168.0.101到192.168.0.200 import subprocess cmd="cmd.exe" b ...

  8. Python学习笔记——基础篇【第七周】———类的静态方法 类方法及属性

    新式类和经典类的区别 python2.7 新式类——广度优先 经典类——深度优先 python3.0 新式类——广度优先 经典类——广度优先 广度优先才是正常的思维,所以python 3.0中已经修复 ...

  9. 《转》python学习(10)-集合

    转自 http://www.cnblogs.com/BeginMan/p/3160565.html 一.目录 1.集合概述 2.关于集合的操作符.关系符号 3.集合的一系列操作(添加.更新.访问.删除 ...

  10. Python学习系列提升篇------字符串

    字符串是python学习中重要的内容,在以后的工作中,对字符串的处理也必少不了.下面总结一下关于字符串学习的经验. 1.1 字符串的连接和合并 用‘ + ’连接,将两个字符串相加.       合并, ...

随机推荐

  1. ZooKeeper集群“脑裂”

    ZooKeeper 集群节点为什么要部署成奇数ZooKeeper 容错指的是:当宕掉几个ZooKeeper节点服务器之后,剩下的个数必须大于宕掉的个数,也就是剩下的节点服务数必须大于n/2,这样Zoo ...

  2. window10搭建pyspark(超级详细)

    一.组件版本说明 Java JDK:1.8.0_144 spark-2.4.3-bin-hadoop2.7hadoop-2.7.7 scala-2.12.8 hadooponwindows-maste ...

  3. openstack octavia的实现与分析(二)原理,架构与基本流程

    [了解] 其实说白了,Octavia就是将用户的API请求经过逻辑处理,转换成Haproxy或者Nginx的配置参数,下发到amphora虚机中. Octavia的内部实现中,逻辑流程的处理主要使用T ...

  4. 图片质量评估论文 | 无监督SER-FIQ | CVPR2020

    文章转自:同作者微信公主号[机器学习炼丹术].欢迎交流,共同进步. 论文名称:SER-FIQ: Unsupervised Estimation of Face Image Quality Based ...

  5. 【Redis3.0.x】持久化

    Redis3.0.x 持久化 概述 Redis 提供了两种不同的持久化方式: RDB(Redis DataBase)持久化,可以在指定的时间间隔内生成数据集的时间点快照. AOF(Append Onl ...

  6. Linux学习笔记 | 常见错误之无法获得锁

    问题: 当运行sudo apt-get install/update/其他命令时,会出现如下提示: E: 无法获得锁 /var/lib/dpkg/lock-frontend - open (11: 资 ...

  7. DHCP最佳实践(三)

    这是Windows DHCP最佳实践和技巧的最终指南. 如果您有任何最佳做法或技巧,请在下面的评论中发布它们. 在本指南(三)中,我将分享以下DHCP最佳实践和技巧. 仅在需要时才使用IP冲突检测 运 ...

  8. 【Docker】/usr/bin/docker-current: Cannot connect to the Docker daemon at unix

    ------------------------------------------------------------------------------------------------- | ...

  9. 使用yaml配置文件管理资源

    [root@k8s-master ~]# vim nginx-deployment.yaml apiVersion: apps/v1beta2 kind: Deployment metadata: n ...

  10. 未使用绑定变量对share_pool的影响

    oracle SGA中包含数据高速缓冲,重做日志缓冲,以及共享池(share_pool).共享池中包含库高速缓冲(所有的SQL,执行计划等)和数据字典缓冲(对象的定义,权限等). 所以,如果SQL中没 ...