集合(set)

集合是由不同可hash的值组成的,里面所有的值都是唯一的,也是无序的

集合的创建

>>>set_test = {"name", "age", "hometown"}
## 把值放入{ }中 >>>lis = ("name", "age", "hometown")
>>>set_test = set(lis)
>>> set_test
{'name', 'age', 'hometown'}
##利用set()函数,把其他类型转换为set >>> list_test = ["name", "age", "hometown"]
>>> set_test = frozenset(list_test)
>>> set_test
frozenset({'name', 'age', 'hometown'})
##利用frozenset()函数可以创造一个set,并把它放到元组里面

集合的操作

  • add(self, *args, **kwargs)

    添加值到集合里面

    >>> set_test
    {'name', 'age', 'hometown'}
    >>> set_test.add("hobby")
    >>> set_test
    {'name', 'age', 'hobby', 'hometown'}
  • clear(self, *args, **kwargs)

    清空集合

  • copy(self, *args, **kwargs)

    浅拷贝

  • discard(self, *args, **kwargs)

    删除某值,没有时不会报错

    >>> set_test
    {'name', 'age', 'hobby', 'hometown'}
    >>> set_test.discard("hobby")
    >>> set_test
    {'name', 'age', 'hometown'}
  • pop(self, *args, **kwargs)

    当集合是由列表和元组组成时,set.pop()是从左边删除元素的,并且可以得到被删除的值

    >>> set_test
    {'name', 'age', 'hometown'}
    >>> set_test.pop()
    'name'
    >>> set_test.pop()
    'age'
  • remove(self, *args, **kwargs)

    删除某值,但是如果没有的话,就会报错

    >>> set_test = {'name', 'age', 'hometown'}
    >>> set_test.remove("hometown")
    >>> set_test
    {'name', 'age'}
  • update(self, *args, **kwargs)

    更新值,可以在set里面添加多个值

    >>> set_test = {"Jack", "Mark", "Ada"}
    >>> set_test.update(["Jewish", "Obanma", "Anna"])
    >>> print(set_test)
    {'Obanma', 'Mark', 'Jack', 'Anna', 'Ada', 'Jewish'}

集合的运算

  • 求交集

    >>> set_test1 = {"YuanMing", "Hermaeus", "Chenglong", "Kelan"}
    >>> set_test2 = {"YuanMing", "Hermaeus", "ZhangJie","Jack"} >>> test_result = set_test1.intersection(set_test2)
    >>> print(test_result)
    {'YuanMing', 'Hermaeus'} >>> test_result = set_test1&set_test2
    >>> print(test_result)
    {'YuanMing', 'Hermaeus'}
  • 求并集

    >>> set_test1 = {"YuanMing", "Hermaeus", "Chenglong", "Kelan"}
    >>> set_test2 = {"YuanMing", "Hermaeus", "ZhangJie","Jack"} >>> test_result = set_test1.union(set_test2)
    >>> print(test_result)
    {'Kelan', 'YuanMing', 'ZhangJie', 'Jack', 'Hermaeus', 'Chenglong'} >>> test_result = set_test1|set_test2
    >>> print(test_result)
    {'Kelan', 'YuanMing', 'ZhangJie', 'Jack', 'Hermaeus', 'Chenglong'}
  • 求差集

    >>> set_test1 = {"YuanMing", "Hermaeus", "Chenglong", "Kelan"}
    >>> set_test2 = {"YuanMing", "Hermaeus", "ZhangJie","Jack"} >>> test_result = set_test1.difference(set_test2)
    >>> test_result1 = set_test1.difference(set_test2)
    >>> print(test_result1)
    {'Kelan', 'Chenglong'} >>> test_result1 = set_test1-set_test2
    >>> print(test_result1)
    {'Kelan', 'Chenglong'} >>> test_result2 = set_test2.difference(set_test1)
    >>> print(test_result2)
    {'ZhangJie', 'Jack'} >>> test_result2 = set_test2-set_test1
    >>> print(test_result2)
    {'ZhangJie', 'Jack'}
  • 求交叉补集

    >>> set_test1 = {"YuanMing", "Hermaeus", "Chenglong", "Kelan"}
    >>> set_test2 = {"YuanMing", "Hermaeus", "ZhangJie","Jack"}
    >>> test_result = set_test1.symmetric_difference(set_test2)
    >>> print(test_result)
    {'ZhangJie', 'Jack', 'Kelan', 'Chenglong'}
    >>> test_result = set_test1^set_test2
    >>> print(test_result)
    {'ZhangJie', 'Jack', 'Kelan', 'Chenglong'}
  • 求集赋值

    • symmetric_difference_update(self, *args, **kwargs)

      >>> set_test1 = {"Jack", "Mark", "Devid"}
      >>> set_test2 = {"Jack", "Marish", "Good"} >>> set_test1.symmetric_update(set_test2)
      >>> set_test1.symmetric_difference_update(set_test2) ## 把得到值赋予set_test1
      >>> set_test1, set_test2
      ({'Good', 'Marish', 'Devid', 'Mark'}, {'Good', 'Jack', 'Marish'}) >>> set_test1 ^= set_test2
      >>> set_test1
      {'Good', 'Marish', 'Devid', 'Mark'}
    • intersection_update(self, *args, **kwargs)

      >>> set_test1 = {"Jack", "Mark", "Devid"}
      >>> set_test2 = {"Jack", "Marish", "Good"} >>> set_test1.intersection_update(set_test2) ##把得到的值赋予set_test1
      >>> set_test1, set_test2
      ({'Jack'}, {'Good', 'Jack', 'Marish'}) >>> set_test1 &= set_test2
      >>> set_test1
      {'Jack'}
    • difference_update(self, *args, **kwargs)

      >>> set_test1 = {"Jack", "Mark", "Devid"}
      >>> set_test2 = {"Jack", "Marish", "Good"} >>> set_test1.difference_update(set_test2)
      >>> set_test1, set_test2
      ({'Devid', 'Mark'}, {'Good', 'Jack', 'Marish'})
      >>> set_test1 = {"Jack", "Mark", "Devid"}
      >>> set_test2 = {"Jack", "Marish", "Good"} >>> set_test1 -= set_test2
      >>> set_test1
      {'Devid', 'Mark'}
    • set_test1 |= set_test2

      >>> set_test1 = {"Jack", "Mark", "Devid"}
      >>> set_test2 = {"Jack", "Marish", "Good"}
      >>> set_test1 |= set_test2
      >>> set_test1

子集与父集

  • issubset(self, *args, **kwargs)

    A.issubset(B) A是B的子集吗? 返回bool

    >>> set_test2 = {"Jack", "Marish", "Good"}
    >>> set_test1 = {"Jack"}
    >>> set_test2.issubset(set_test1)
    False
    >>> set_test1.issubset(set_test2)
    True
  • issuperset(self, *args, **kwargs)

    A.issuperset(B) A是B的父集吗? 返回bool

    >>> set_test2 = {"Jack", "Marish", "Good"}
    >>> set_test1 = {"Jack"}
    >>> set_test1.issuperset(set_test2)
    False
    >>> set_test2.issuperset(set_test1)
    True
  • isdisjoint(self, *args, **kwargs)

    返回True如果两个set没有交集

    >>> set_test1 = {"Jack", "Mark", "Devid"}
    >>> set_test2 = {"Ada", "Marish", "Good"}
    >>> set_test1.isdisjoint(set_test2)
    True
  • <,<= OR >,>=

    >>> set_test1 = {"Jack", "Mark", "Devid"}
    >>> set_test2 = {"Jack", "Mark"
    >>> set_test1 < set_test2
    False
    >>> set_test1 > set_test2
    True

Python集合及其运算的更多相关文章

  1. python集合的运算

    &  交集  | 并集    - 差集  ^ 异或集 # 在对集合做运算时,不会影响原来的集合,而是返回一个运算结果 # 创建两个集合 s = {1,2,3,4,5} s2 = {3,4,5, ...

  2. 初学Python——集合及其运算

    一.集合定义及其功能 集合是一个无序的.不重复的数据组合,和字典列表一样也是一种数据类型. 集合两个最主要的功能:①去重(把一个列表变成集合,就自动去重了) ②关系测试(测试两组数据之间的交.并.差集 ...

  3. day14 Python集合关系运算交,差,并集

    low逼写法,没用集合 python_1 = ['charon','pluto','ran'] linux_1 = ['ran','xuexue','ting'] python_and_linux = ...

  4. python 集合的运算

    x = frozenset([, , , , ]) y = frozenset([, , , , ]) #如果x与y没有公共元素,返回true print(x.isdisjoint(y)) #返回x与 ...

  5. Python全栈之路3--set集合--三元运算--深浅拷贝--初识函数

    一.上节课的重点回顾: 1.类名加括号其实就是执行类的__init__方法: 2.int a.创建方式 n1 = 123 #根据int类创建了一个对象 n2 = int(123) #根据int类创建一 ...

  6. python集合类型

    集合类型简介 集合也是容器,其内元素都是无序.唯一.不可变的.它常用来做成员测试.移除重复数据.数据计算(比如交集.并集.差集). 集合Set是dict的无value版.集合也使用大括号包围: > ...

  7. python集合与字典的用法

    python集合与字典的用法 集合: 1.增加  add 2.删除   •del 删除集合 •discard(常用)删除集合中的元素  #删除一个不存在的元素不会报错 •remove 删除一个不存在的 ...

  8. Python—集合的操作、文件的操作

    1.集合的操作 2.文件的操作 1.集合的操作 定义: 1.不同元素组成,自动去重 2.无序 3.集合中的元素必须是不可变类型 1.集合的定义: >>> s1 = set('abcd ...

  9. python集合、元组、字典

    主要内容: 2.集合 3.元组 4.字典 复习: 字符串和元组一样,只能读不能写.列表和字典可以嵌套任何东西,列表可以嵌套列表 L = list("hello")  # L = [ ...

随机推荐

  1. 【底层原理】深入理解Cache (上)

    存储器是分层次的,离CPU越近的存储器,速度越快,每字节的成本越高,同时容量也因此越小.寄存器速度最快,离CPU最近,成本最高,所以个数容量有限,其次是高速缓存(缓存也是分级,有L1,L2等缓存),再 ...

  2. 数组实例的 copyWithin()

    用途:在当前数组内部,将指定位置的成员复制到其他位置(会覆盖原有成员),然后返回当前数组.也就是说,使用这个方法,会修改数组本身. 用法:Array.prototype.copyWithin(targ ...

  3. About Swift

    Swift is a new programming language for iOS and OS X apps that builds on the best of C and Objective ...

  4. node访问oracledb的环境搭建

    关于安装oracleDB环境官网说明地址: https://oracle.github.io/node-oracledb/INSTALL.html 环境搭建所需软件和文档的压缩包 链接: https: ...

  5. pm2命令,端口查询,mongodb服务启动,nginx服务启动,n模块的使用,搭建nodejs服务器环境,搭建oracledb服务器环境 linux的环境搭建

    pm2命令 pm2 ls //查询pm2 启动的列表 pm2 start app.js //启动文件 pm2 restart app //重启项目 pm2 logs app //监控项目执行日志打印 ...

  6. Python+Pycharm—学习—pip

    1.pip是干什么的? 2.pip怎么安装? 3.pip怎么用?

  7. 初学Python——字符串相关操作

    基本字符串操作 Pyhton中字符串的格式化输出在前面已经总结了,接下来介绍一些常用的字符串操作 先定义一个字符变量,以下的操作都以此为例: name=" my name is china ...

  8. OpenCV3计算机视觉Python语言实现笔记(一)

    Python3下OpenCV的安装 :http://blog.csdn.net/lwplwf/article/details/61616493 1. 读/写图像文件 OpenCV的imread()函数 ...

  9. AI LeNet

    LeNet 参考链接: http://yann.lecun.com/exdb/publis/pdf/lecun-01a.pdf https://www.charleychai.com/blogs/20 ...

  10. redis学习(二)——String数据类型

    一.概述 字符串类型是Redis中最为基础的数据存储类型,它在Redis中是二进制安全的,这便意味着该类型可以接受任何格式的数据,如JPEG图像数据或Json对象描述信息等.在Redis中字符串类型的 ...