一,集合

  1,集合由不同元素组成

  2,无序

  3,集合中元素必须是不可变类型

二,定义集合

  1,s = {1,2,3,4,5}

  2,s = set(hello)以迭代的方式生成集合

s = set("hello")
print(s) {'o', 'e', 'h', 'l'}

  

三,集合的方法

  1,add添加,如果添加有重复不会报错但是也不会添加

s = {1,2,3}
s.add(4)
print(s) {1, 2, 3, 4}

  

  2,clear清除

  3,copy拷贝

s = {1,2,3}
s1 = s.copy()
print(s) {1,2,3}

  

  4,pop删除,因为是无序的所以是随机删除

  5,remove指定删除,如果指定参数没有则报错不存在KeyError

s = {1,2,3}
s.remove(1)
print(s) {2,3}

  

  6,discard和remove功能一样不过是假如没有找到关键字不会报错

四,集合的运算

  1,并集

  假设有两个列表一个列表列出学习python的学生一个列出学习linux的学生请列出既学习了python的又学习了linux的学生

  通过循环的方法vim day14-2.py

python_l = ['zhangsan','lisi','wangwu']
linux_l = ['zhangsan','lisi']
python_and_linux_l = []
for p_name in python_l:
if p_name in linux_l:
python_and_linux_l.append(p_name)
print(python_and_linux_l) ['zhangsan', 'lisi']

  这种方法比较low下面用集合来处理 vim day14-3.py

python_l = ['zhangsan','lisi','wangwu']
linux_l = ['zhangsan','lisi']
#把列表转换成无序的集合
p_s = set(python_l)
l_s = set(linux_l)
print(p_s.intersection(l_s))
print(p_s&l_s)

  使用print(p_s&l_s)更加简单

  2,和集

  使用union或者符号

  

  3,差集

  直接使用-号即可,存在于键鼠不存在于被减数中的元素

  p_s - l_s

  4,交叉补集symmetric_difference 符号^ 先合集在减去并集就是交叉补集

python_l = ['zhangsan','lisi','wangwu']
linux_l = ['zhangsan','lisi','dage']
#把列表转换成无序的集合
p_s = set(python_l)
l_s = set(linux_l)
print(p_s.symmetric_difference(l_s))

  

  5,difference_update求完差集并更新原集合返回值为None 以下操作相当于p_s = p_s - l_s

python_l = ['zhangsan','lisi','wangwu']
linux_l = ['zhangsan','lisi']
#把列表转换成无序的集合
p_s = set(python_l)
l_s = set(linux_l)
v = p_s.difference_update(l_s)
print(p_s,v) {'wangwu'} None

  

  6,isdisjoint 两个集合没有交集返回True有交集返回False

s1 = {1,2}
s2 = {3,4}
print(s1.isdisjoint(s2)) True

  

  7,issubset一个集合是否是另外一个集合的子集 如果是返回True如果不是返回False

s1 = {1,2}
s2 = {1,2,3,4}
print(s1.issubset(s2)) True

  

  8,issuperset判断一个集合是否是另外一个集合的父集

  9,update并集并且更新和union不同的是union不会更新

s1 = {1,2}
s2 = {1,2,3}
s1.update(s2)
print(s1) {1,2,3}

  

五,集合的补充

  

  1,frozenset定义不可变集合

s = frozenset('hello')
print(s) frozenset({'e', 'h', 'l', 'o'})

  2,列表使用集合的方法去重,但是新生成的列表顺序可能和原列表不同

names = ['zhangsan','zhangsan','lisi']
names = list(set(names))
print(names) ['lisi', 'zhangsan']

  

  

Python全栈day14(集合)的更多相关文章

  1. Python全栈day14(字符串格式化)

    一,%字符串格式化 1,使用%s 后面一一对应输入对应的字符串,%s可以接受任何参数 print ("I am %s hobby is zhangsan"%'lishi') pri ...

  2. 老男孩Python全栈第2期+课件笔记【高清完整92天整套视频教程】

    点击了解更多Python课程>>> 老男孩Python全栈第2期+课件笔记[高清完整92天整套视频教程] 课程目录 ├─day01-python 全栈开发-基础篇 │ 01 pyth ...

  3. Python全栈开发【模块】

    Python全栈开发[模块] 本节内容: 模块介绍 time random os sys json & picle shelve XML hashlib ConfigParser loggin ...

  4. Python全栈开发【基础四】

    Python全栈开发[基础四] 本节内容: 匿名函数(lambda) 函数式编程(map,filter,reduce) 文件处理 迭代器 三元表达式 列表解析与生成器表达式 生成器 匿名函数 lamb ...

  5. Python全栈开发【基础三】

    Python全栈开发[基础三]  本节内容: 函数(全局与局部变量) 递归 内置函数 函数 一.定义和使用 函数最重要的是减少代码的重用性和增强代码可读性 def 函数名(参数): ... 函数体 . ...

  6. Python全栈开发【基础二】

    Python全栈开发[基础二] 本节内容: Python 运算符(算术运算.比较运算.赋值运算.逻辑运算.成员运算) 基本数据类型(数字.布尔值.字符串.列表.元组.字典) 其他(编码,range,f ...

  7. Python全栈考试-部分试题(精选)

    Python全栈考试(一) Python全栈考试(一) 1.执行 Python 脚本的两种方式 答:1.>>python ../pyhton.py 2. >>python.py ...

  8. Python全栈之路目录结构

    基础 1.Python全栈之路-----基础篇 2.Python全栈之路---运算符与基本的数据结构 3.Python全栈之路3--set集合--三元运算--深浅拷贝--初识函数 4.Python全栈 ...

  9. python 全栈开发之路 day1

    python 全栈开发之路 day1   本节内容 计算机发展介绍 计算机硬件组成 计算机基本原理 计算机 计算机(computer)俗称电脑,是一种用于高速计算的电子计算机器,可以进行数值计算,又可 ...

随机推荐

  1. OpenCV2马拉松第24圈——轮廓提取

    计算机视觉讨论群162501053 转载请注明:http://blog.csdn.net/abcd1992719g/article/details/27979267 收入囊中 在图片中找到轮廓而且描绘 ...

  2. 微信client内部推荐项目总结

    如今实习的公司在面向企业提供招聘服务领域数一数二,而下半年的产品重点就在于移动端微信招聘项目.而这次内推项目开发属于微信招聘一个分支.     一.内推综述     乐帝之前读<招聘与录用> ...

  3. python随机数seed用法

    import random ... def main(): a = random.Random() a.seed(1) print a.random() 这样就可以通过种子取得固定随机值了 网上很多只 ...

  4. Java并发之彻底搞懂偏向锁升级为轻量级锁

    网上有许多讲偏向锁,轻量级锁的文章,但对偏向锁如何升级讲的不够明白,有些文章还相互矛盾,经过对jvm源码(biasedLocking.cpp)的仔细分析和追踪,基本升级过程有了一个清晰的过程,现将升级 ...

  5. 【转】Elasticsearch5.0 安装问题集锦

    Elasticsearch5.0 安装问题集锦 elasticsearch 5.0 安装过程中遇到了一些问题,通过查找资料几乎都解决掉了,这里简单记录一下 ,供以后查阅参考,也希望可以帮助遇到同样问题 ...

  6. django 运行不同的settings

    python manage.py runserver --settings=EMCRP.settings_local

  7. SHLVL--shell终端深度

    参考:How And Why You Would Use The $SHLVL Variable SHLVL代表shell打开的深度,进程第一次打开shell时$SHLVL=1,然后在此shell中再 ...

  8. Docker Swarm学习教程

    原创作品,转载请注明出处:点我 Swarm介绍 Swarm是Docker公司在2014年12月初发布的一套较为简单的工具,用来管理Docker集群,它将一群Docker宿主机变成一个单一的,虚拟的主机 ...

  9. Requests blocked by CORS policy in spring boot and angular

    在本地启动Spring Boot后端和Angular前端调试时遇到跨域访问的问题导致前端请求失败. 错误描述 Access to XMLHttpRequest at 'http://localhost ...

  10. LRU算法 - LRU Cache

    这个是比较经典的LRU(Least recently used,最近最少使用)算法,算法根据数据的历史访问记录来进行淘汰数据,其核心思想是“如果数据最近被访问过,那么将来被访问的几率也更高”. 一般应 ...