一:学习内容

  • 集合概念
  • 集合创建
  • 集合添加
  • 集合插入
  • 集合删除
  • 集合访问
  • 集合操作:并集、交集

二:集合概念

1.set:类似dict,是一组key的集合,不存储value

2.本质:无序和无重复元素的集合

3.可使用大括号 {}或者set()函数创建集合;创建一个空集合必须是set(),{}代表的是空字典

三:集合创建

创建set需要一个list或者tuple或者dict作为输入集合,打印效果看着像排好序的,其实是无序的

1.创建set--用list作为输入

#用list作为输入
s1 = set([1,2,3,4,5])
print(s1)
s2 = set([1,3,2,5,4,5,2])
print(s2)

2.创建set--用tuple作为输入

#用tuple作为输入
s3 = set((1,2,3,4,5))
print(s3)
s4 = set((1,3,2,5,4,5,2))
print(s4)

3.创建set-用dict作为输入

#用dict作为输入
s5 = set({"name":"tester","age":18})
print(s5)

四:集合添加

集合名.set(x) 添加,将x作为一个整体直接全部添加到set中,x不能为字典和列表,因为字典和列表是可变的不能作为key

1.添加一个数字

s6 = set([1,2,3,4,5])
s6.add(6)
print(s6)

#添加重复值,不会有效果,因为过滤了
s7 = set([1,2,3,4,5])
s7.add(5)
print(s7)

2.添加一个列表,报错,因为list是可变的不能作为key

s8 = set([1,2,3,4,5])
s8.add([7,8,9])           #列表是可变的,不能作为key

3.添加一个元组,可以,因为tuple是不可变的,可以作为key

s9 = set([1,2,3,4,5])
s9.add((7,8,9))
print(s9)

4.添加一个字典,报错,因为字典是可变的,不可以作为key

s10 = set([1,2,3,4,5])
s10.add({1:"a"})      #报错,因为字典是可变的不能作为key
print(s10)

5.添加一个字符串,可以,因为字符串是不可变的,可以作为key

s10 = set([1,2,3,4,5])
s10.add("tester")
print(s10)

五:集合插入

集合名.update(x) 将x中每一项遍历插入到集合中

1.插入列表

s11 = set([1,2,3,4,5])
s11.update([6,7,8])
print(s11)

2.插入元组

s11 = set([1,2,3,4,5])
s11.update((6,7,8))
print(s11)

3.插入字符串,将字符串中每一项一项一项往里插入

s12 = set([1,2,3,4,5])
s12.update("test")     #会插入{'t','e','s'}
print(s12)

六:集合删除

集合名.remove(x),删除x元素

1.删除集合

s13 = set([1,2,3,4,5])
s13.remove(1)

s13 = set([1,2,3,4,5])
s13.remove(6)  #没有这个元素就报错
print(s13)

2.删除集合

s14 = set((1, 2, 3, 4, 5, (7, 8, 9)))
s14.remove(7)  #报错

s14 = set((1, 2, 3, 4, 5, (7, 8, 9)))
s14.remove((7,8,9))
print(s14)

七:集合访问

1.遍历

s15 = set((1, 2, 3, 4, 5, (7, 8, 9)))
for i in s15:
    print(i)   #最后一个会打印(7,8,9)

2.集合是无序的,所以取出来是乱序的,每次打印的结果都可能不一样

s={"a","b","c"}
print(s)

3.集合是没有索引的

s17 = set([1, 2, 3, 4, 5])
print(s17[0])  #报错,set没有索引

4.集合枚举遍历,虽然能拿到下标,但是其实是乱序的,每次打印下标对应的值可能都不一样

s17 = set(["a", "b", "c", "d", "e"])
for index,data in enumerate(s17):
    print(index,data)

八:集合操作

并集:两者相加
交集:相同部分

1.交集

s18 = set([1,2,3])
s19 = set([2,3,4])
s20 = s18 & s19    #交集为{2,3}
print(s18)
print(s20)
print(type(s20))

2.并集

s18 = set([1,2,3])
s19 = set([2,3,4])
s21 = s18 | s19      #并集为{1,2,3,4}
print(s18)
print(s21)
print(type(s21))

python3笔记十三:python数据类型-Set集合的更多相关文章

  1. 【转】Python数据类型之“集合(Sets)与映射(Mapping)”

    [转]Python数据类型之“集合(Sets)与映射(Mapping)” 一.集合类型(Sets) 集合对象是不同的(不可重复)hashable对象的无序集合.常见用法包括:成员关系测试.移除序列中的 ...

  2. Python笔记_第一篇_面向过程_第一部分_5.Python数据类型之集合类型(set)

    集合!Python中的集合数据基本上是为了方便数学计算使用的. 什么是集合? 集合就是“确定的一堆东西”.集合里面的东西叫做元素. 特点:1. 集合里面是没有重复的元素的.           2. ...

  3. 7、python数据类型之集合set

    数据类型之集合setset 不允许重复的无序集合,不能通过下标取值,因为无序1.创建   创建空集合   s ={} 默认类型为字典,所以不是空集合,空集合如下   s = set()   s = { ...

  4. python 数据类型之集合

    一.集合的定义: 定义:由不同元素组成的集合,集合中是一组无序排列的可hash值,可以作为字典的key. 特性:集合的目的是将不同的值存放到一起,不同的集合间用来做关系运算,无需纠结于集合中单个值 二 ...

  5. python学习笔记(二):python数据类型

    上一篇博客写了python的入门和简单流程控制,这次写python的数据类型和各种数据类型的内置方法.一.数据类型是什么鬼?计算机顾名思义就是可以做数学计算的机器,因此,计算机程序理所当然地可以处理各 ...

  6. Python数据类型-8 集合set

    集合set set集合是一个无序不重复元素的集,基本功能包括关系测试和消除重复元素.集合使用大括号({})框定元素,并以逗号进行分隔.但是注意:如果要创建一个空集合,必须用 set() 而不是 {} ...

  7. Python—数据类型之集合(Set)

    1.集合是一个无序的,且不重复元素的集合.它里面的元素是可哈希的(不可变类型),但是集合本身是不可哈希(所以集合做不了字典的键)的. 2.基本功能包括关系测试和消除重复元素.注意:集合存在的意义就是去 ...

  8. Python数据类型之“集合(Sets)与映射(Mapping)”

    一.集合类型(Sets) 集合对象是不同的(不可重复)hashable对象的无序集合.常见用法包括:成员关系测试.移除序列中的重复.以及科学计算,例如交集.并集.差分和对称差分.通俗点来说,集合是一个 ...

  9. Python基础-python数据类型之集合(四)

    集合 集合是一个无序的,不重复的数据组合,基本功能包括关系测试和消除重复元素. 集合对象还支持 union,intersection,difference和 sysmmetric difference ...

随机推荐

  1. 使用JavaScript实现字符串格式化

    使用JavaScript实现字符串格式化 String.prototype.format = function (kwargs) { /* hello-{n}-{m} {'n':'word','m': ...

  2. 浅析java中clone()方法

    本文转载自:http://blog.csdn.net/mengxiangyue/article/details/6818611 Java中我们可能都遇到过这样的情况,在我们将一个对象做为参数传给一个函 ...

  3. 爬取YY评级信息

    #!/usr/bin/env python # -*- coding: utf-8 -*- # @File : 爬取YY评级基本信息.py # @Author: lattesea # @Date : ...

  4. CSS media queries 媒体查询

    最近在做一些页面打印时的特殊处理接触到了media queries,想系统学习一下,在MOZILLA DEVELOPER NETWORK看到一篇文章讲的很不错,结合自己的使用总结一下. CSS2/me ...

  5. python3.7 利用pyhive 连接上hive(亲测可用)

    来python爬虫中,经常会遇到数据的存储问题,如果有大量数据,hive存储是个不错的选择. 那么python如何来连接hive呢?网上有各种教程但是都不是很好用,亲自测试pyhive可用 要求:可用 ...

  6. Linux下svn服务器的安装与配置-备份-恢复-计划任务

    简介:SVN是Subversion的简称,是一个开放源代码的版本控制系统,相较于RCS.CVS,它采用了分支管理系统,它的设计目标就是取代CVS.互联网上很多版本控制服务已从CVS迁移到Subvers ...

  7. Logback日志输出到ELK

    用docker-compose本机部署elk docker-compose.yml version: "3" services: es01: image: docker.elast ...

  8. deep_learning_Function_numpy.linspace()

    numpy.linspace()等差数列函数 在numpy中的linspace()函数类似与arange().range()函数: arange() .range() 可以通过指定开始值.终值和步长创 ...

  9. HAproxy企业应用,TCP/HTTP动静分离

    HAProxy的是一个免费的.开源的的tcp/http反向代理工具.负载均衡器,是一个企业非常快速和可靠的安全的解决方案,提供高可用性.高并发性,负载均衡和代理对TCP和基于HTTP的应用程序.它特别 ...

  10. Linux搭建局域网yum源和后期在yum源中更新rpm包方法

    在内网中搭建自己的yum源,可以方便在内网中使用,下面简单介绍搭建局域网yum源的方法和后期更新yum源rpm包的方法. 一.搭建局域网yum源 1.需要在局域网访问,首先需要一个web服务器,比如a ...