set 叫做集合

 作用:

 去重(去除重复)

举例——

>>> name_list = ['alben','nichole','lucy','andy','tom','alben']

>>> type(name_list)

<class 'list'>

>>> name_list

['alben', 'nichole', 'lucy', 'andy', 'tom', 'alben']

这个list中,有一个元素重复出现了2次‘alben’

通过set可以进行去重

>>> set1 = set(name_list)
>>> set1
{'andy', 'tom', 'lucy', 'nichole', 'alben'}

对set可以实施的操作:

1,‘add’  追加元素

>>>set1.add('curry')
>>> set1
{'andy', 'lucy', 'tom', 'alben', 'curry', 'nichole'}

2,‘clear’ 清除所有元素

>>> set1.clear()
>>> set1
set()

3,‘difference’  把set与列表进行对比,找出不同的

>>> name_list1 = ['alben','nichole','andy','lucy','tom','stephen']
>>> name_list2 = ['harden','tom','curry','thompson']
>>> set1 = set(name_list1)
>>> set1.difference(name_list2)
{'stephen', 'nichole', 'alben', 'andy', 'lucy'}

解释:

 在这里有两个列表:name_list1,与name_list2,

通过set()把name_list1转换成了set,并且命名为set1

对set1进行difference(),与name_list2 进行对比,输出的结果是

{'stephen', 'nichole', 'alben', 'andy', 'lucy'}

其实就是把set1与name_list1进行对比,取出哪些set1中存在的,但是name_list2中没有的元素。

可以把difference的结果输出到表格或者另一个set

>>> name_list3 =[set1.difference(name_list2)]  #如果这里不加【】的话,name_list3 就是一个‘set’
>>> type(name_list3)

<class 'list'>
>>> name_list3
[{'stephen', 'nichole', 'alben', 'andy', 'lucy'}]

4,difference_update  与difference的功能相同,都是寻找不同的元素,差别是difference_update直接更新原有set

>>> set1.difference_update(name_list2)
>>> set1
{'stephen', 'nichole', 'alben', 'andy', 'lucy'}

#效果显而易见#

5、remove 从set中删除一个元素

>>> set1
{'stephen', 'nichole', 'alben', 'andy', 'lucy'}
>>> set1.remove('andy')
>>> set1
{'stephen', 'nichole', 'alben', 'lucy'}

6,discard 从set中删除一个元素

>>> set1
{'stephen', 'nichole', 'alben', 'andy', 'lucy'}
>>> set1.discard('andy')
>>> set1
{'stephen', 'nichole', 'alben', 'lucy'}

 remove()与discard()的区别:

remove()如果元素不不存在,报错

discard()如果元素不存在,不会报错

7,intersection 交集(初中数学集合知识)

>>> set1
{'stephen', 'tom', 'nichole', 'alben', 'andy', 'lucy'}
>>> name_list2
['harden', 'tom', 'curry', 'thompson']
>>> set3 = set1.intersection(name_list2)
>>> set3
{'tom'}

用图解释交集

7,intersection_update(获取交集,在原来的set上进行升级,而不是输出到新的set)

8,isdisjoint 判断是否相交

 如果相交 返回 False

 反之,返回True

>>> s1
{1, 2, 3, 4, 5}
>>> num2
[6, 7, 8, 9, 10]
>>> num3
[1, 3, 5, 7, 9]
>>> s1.isdisjoint(num2)
True
>>> s1.isdisjoint(num3)
False

 8、issubset 判断集合中的所有元素是否在给定的列表/集合中

举例:

>>> num1
[1, 2, 3, 4, 5, 6, 7, 8, 9]
>>> num2
[1, 3, 5, 7, 9]
>>> num3
[0, 2, 4, 6, 8]
>>> s1=set(num2)
>>> s1
{1, 9, 3, 5, 7}
>>> s1.issubset(num1)
True

9,issuperset 判断当前集合是否全部包含给定的列表/集合

>>> s1
{1, 9, 3, 5, 7}
>>> s0
{1, 2, 3, 4, 5, 6, 7, 8, 9}
>>> s0.issuperset(s1)    #s0完全包含s1# 所以返回True

True
>>> s1.issuperset(s0)    #s1并不是完全包含s0# 所以返还False
False

10,symmetric_difference()

用法:

set1.symmetric_difference(set2)

图示:

结果:

B删除,输出A+C

示例:

>>> num1=[1,2,3,4,5,6]
>>> num2=[2,4,6,8,10]
>>> s1 = set(num1)
>>> s1
{1, 2, 3, 4, 5, 6}
>>> s1.symmetric_difference(num2)
{1, 3, 5, 8, 10}

解释#在s1中有{1,2,3,4,5,6}

在list=num2中有[2,4,6,8,10]

解答:

交集部分:
[2 4 6]

C 独有部分 [8,10]

最后 {1,2,3,4,5,6}-[2,4,6]+[8,10]=[1,3,5,8,10]

11,symmetric_difference_update()

同理symmetric_difference,只是只是在原set上更新

12,union(合并)

>>> s1
{1, 2, 3, 4, 5, 6}
>>> s2
{8, 2, 10, 4, 6}
>>> s1.union(s2)
{1, 2, 3, 4, 5, 6, 8, 10}

13,update 添加多个元素

set集合(一)的更多相关文章

  1. java基础集合经典训练题

    第一题:要求产生10个随机的字符串,每一个字符串互相不重复,每一个字符串中组成的字符(a-zA-Z0-9)也不相同,每个字符串长度为10; 分析:*1.看到这个题目,或许你脑海中会想到很多方法,比如判 ...

  2. .Net多线程编程—并发集合

    并发集合 1 为什么使用并发集合? 原因主要有以下几点: System.Collections和System.Collections.Generic名称空间中所提供的经典列表.集合和数组都不是线程安全 ...

  3. 一起学 Java(三) 集合框架、数据结构、泛型

    一.Java 集合框架 集合框架是一个用来代表和操纵集合的统一架构.所有的集合框架都包含如下内容: 接口:是代表集合的抽象数据类型.接口允许集合独立操纵其代表的细节.在面向对象的语言,接口通常形成一个 ...

  4. 编写高质量代码:改善Java程序的151个建议(第5章:数组和集合___建议75~78)

    建议75:集合中的元素必须做到compareTo和equals同步 实现了Comparable接口的元素就可以排序,compareTo方法是Comparable接口要求必须实现的,它与equals方法 ...

  5. java基础_集合List与Set接口

    List接口继承了Collection的方法  当然也有自己特有的方法向指定位置添加元素   add(索引,添加的元素); 移除指定索引的元素   remove(索引) 修改指定索引的元素   set ...

  6. Java基础Collection集合

    1.Collection是所有集合的父类,在JDK1.5之后又加入了Iterable超级类(可以不用了解) 2.学习集合从Collection开始,所有集合都继承了他的方法 集合结构如图:

  7. 轻量级“集合”迭代器-Generator

    Generator是PHP 5.5加入的新语言特性.但是,它似乎并没有被很多PHP开发者广泛采用.因此,在我们了解PHP 7对Generator的改进之前,我们先通过一个简单却显而易见的例子来了解下G ...

  8. Asp.net MVC 传递数据 从前台到后台,包括单个对象,多个对象,集合

    今天为大家分享下 Asp.net MVC 将数据从前台传递到后台的几种方式. 环境:VS2013,MVC5.0框架 1.基本数据类型 我们常见有传递 int, string, bool, double ...

  9. 这些.NET开源项目你知道吗?.NET平台开源文档与报表处理组件集合(三)

    在前2篇文章这些.NET开源项目你知道吗?让.NET开源来得更加猛烈些吧 和这些.NET开源项目你知道吗?让.NET开源来得更加猛烈些吧!(第二辑)中,大伙热情高涨.再次拿出自己的私货,在.NET平台 ...

  10. python 数据类型 --- 集合

    1. 注意列表和集合的区别 set 列表表现形式: list_1 = [1,3,4];  集合表现形式:set_1= set() list_1 = [1,2,3,4,23,4,2] print(lis ...

随机推荐

  1. js根据条件json生成随机json:randomjson

    前端开发中,在做前后端分离的时候,经常需要手写json数据,有3个问题特别揪心: 1,数据是写死的,不能按一定的条件随机生成长度不一,内容不一的数据 2,写数组的时候,如果有很多条,需要一条一条地写, ...

  2. Apache Beam 剖析

    1.概述 在大数据的浪潮之下,技术的更新迭代十分频繁.受技术开源的影响,大数据开发者提供了十分丰富的工具.但也因为如此,增加了开发者选择合适工具的难度.在大数据处理一些问题的时候,往往使用的技术是多样 ...

  3. Vuex随笔

    最近在项目中使用到了vuex,但是在配合vue使用时,也还是遇到了不少的问题,最终还是解决了问题,因此写一篇随笔来记录期间遇到的问题吧 项目概要: Vuex中所储存的的状态如下: Vue中:有一个ta ...

  4. 【模板】Dijkstra的heap优化

    为了将最小费用最大流的spfa优化,决定将spfa换成heap优化的Dijkstra.(dijkstra不能处理负边权) 所以还得现学... 白点表示已经确定最短路径的点. 蓝点表示还未确定最短路径的 ...

  5. window下安装mysqldb模块(虚拟环境)

    因为在虚拟环境下安装mysql-python走了许多弯路,各种环境问题,特此记录 直接使用pip安装mysql-python会报错 pip install MySQL-python 可以直接选择非虚拟 ...

  6. HYML / CSS部分

    1.什么是盒子模型? 在网页中,一个元素占有空间的大小由几个部分构成,其中包括元素的内容(content),元素的内边距(padding),元素的边框(border),元素的外边距(margin)四个 ...

  7. .net core 利用中间件处理常见的网站功能 包括 session、routers、重定向、重写和文件下载

    在.net core中所有的请求都会被请求中间件所处理,所以我们可以通过在中间件里边添加对应的功能然后在服务中添加注入来实现对应的功能 文件位置:Startup.cs=>Configure方法, ...

  8. SQL Server 中统计信息直方图中对于没有覆盖到谓词预估以及预估策略的变化(SQL2012-->SQL2014-->SQL2016)

    本位出处:http://www.cnblogs.com/wy123/p/6770258.html 统计信息写过几篇了相关的文章了,感觉还是不过瘾,关于统计信息的问题,最近又踩坑了,该问题虽然不算很常见 ...

  9. 关于quotename的用法

    首先,sqlserver里的标识符有一定的规则,比如  你 create table abc 123(...) 那么中间含有空格,它不是符合规则的. 你会写做 create table [abc 12 ...

  10. ThinkPHP 框架模型

     1 在MainController.class.php 控制器中有一个test的方法,同时还有一个deng的方法,我想在test方法中使用deng方法  表示为 <?php namespace ...