博客
关于我
【从零学习python 】23. Python中集合(set)的使用方法和常见操作
阅读量:589 次
发布时间:2019-03-11

本文共 1539 字,大约阅读时间需要 5 分钟。

Python集合(set)的使用指南

集合(set)是Python中的一种数据结构,它是一个无序且不允许重复元素的元素集合。集合在数据处理和操作中非常有用,特别是在需要去重、快速查找和批量操作时。

创建集合

集合在Python中可以通过两种方式创建:

  • 使用大括号语法{value1, value2, ...}创建非空集合。
  • 使用set()函数创建集合,set()函数可以接收多个参数,或者接收一个可迭代对象(如列表、元组、字典等)。
  • 需要注意的是,创建空集合时,必须使用set()函数而不是大括号{},因为大括号在Python中用于创建空字典。

    示例:

    # 创建非空集合
    my_set = {1, 2, 3}
    # 创建空集合
    empty_set = set()

    集合的基本操作

    添加元素

    集合支持通过add()方法添加单个元素,或者使用update()方法批量添加多个元素。

    示例:

    # 添加单个元素
    my_set.add(4)
    # 批量添加多个元素
    my_set.update([5, 6, 7])

    移除元素

    集合支持通过remove()方法移除指定元素,或者使用discard()方法来安全移除指定元素(即使元素不存在也不报错)。

    示例:

    # 移除指定元素
    my_set.remove(3)
    my_set.discard(3) # 如果元素不存在也不报错

    其他常用方法

    集合还提供了许多其他方法,包括:

    • clear():清空集合。
    • copy():复制集合。
    • pop():随机移除一个元素。
    • union():返回两个集合的并集。
    • intersection():返回两个集合的交集。
    • difference():返回两个集合的差集。
    • symmetric_difference():返回两个集合的对称差集。

    下面是一个完整的方法列表:

    方法 描述
    add() 添加一个元素到集合中。
    clear() 移除集合中的所有元素。
    copy() 创建一个新集合的拷贝。
    pop() 随机移除集合中的一个元素,并返回它。
    remove() 移除集合中的一个指定元素。如果元素不存在会抛出错误。
    discard() 移除集合中的一个指定元素。如果元素不存在不会抛出错误。
    update() 将给定的可迭代对象中的元素添加到集合中。如果已存在则忽略。
    union() 返回两个集合的并集。
    intersection() 返回两个集合的交集。
    difference() 返回两个集合的差集。
    symmetric_difference() 返回两个集合的对称差集。
    issubset() 判断该集合是否是另一个集合的子集。
    issuperset() 判断该集合是否是另一个集合的超集。
    superset() 判断另一个集合是否是该集合的子集。
    subset() 判断另一个集合是否是该集合的子集。

    练习:去重并排序

    给定一个包含重复元素的无序列表:

    nums = [5, 8, 7, 6, 4, 1, 3, 5, 1, 8, 4]

    目标:去重并按降序排序。

    方法一:使用集合和内置sort方法

    nums2 = list(set(nums))
    nums2.sort(reverse=True)
    print(nums2)

    方法二:使用sorted内置函数

    print(sorted(list(set(nums)), reverse=True))

    进阶案例:集合的高级使用

    集合在Python中非常灵活,可以与其他数据结构和函数结合使用。例如:

    • 使用集合来存储唯一的键值对。
    • 使用集合进行速度敏感的操作(如哈希表)。
    • 使用集合进行并集、交集等高级操作。

    通过合理使用集合,可以显著提升代码的性能和可读性。

    转载地址:http://luovz.baihongyu.com/

    你可能感兴趣的文章
    MySQL查询结果排序
    查看>>
    MYSQL查询语句优化
    查看>>
    mysql查询语句能否让一个字段不显示出来_天天写order by,你知道Mysql底层执行原理吗?
    查看>>
    MySQL查询语句:揭秘专家秘籍,让你秒变数据库达人!
    查看>>
    mysql查询超时对PHP执行的影响
    查看>>
    mysql查询输出到excel文件_如何保存mysql查询输出到excel或.txt文件?
    查看>>
    mysql查询过程
    查看>>
    MySQL死锁套路:一次诡异的批量插入死锁问题分析
    查看>>
    Mysql死锁问题Deadlock found when trying to get lock;try restarting transaction
    查看>>
    mysql每个数据库的最大连接数_MySQL数据库最大连接数
    查看>>
    Mysql流程控制结构,if函数、case结构、if结构、循环结构
    查看>>
    mysql添加外网访问权限
    查看>>
    mysql添加用户
    查看>>
    MySQL添加用户、删除用户与授权
    查看>>
    mysql添加用户及权限
    查看>>
    Mysql添加用户并授予只能查询权限
    查看>>
    mysql添加用户权限报1064 - You have an error in your SQL syntax问题解决
    查看>>
    mysql添加索引
    查看>>
    mysql添加表注释、字段注释、查看与修改注释
    查看>>
    mysql清理undo线程_MySQL后台线程的清理工作
    查看>>