上手Python之set(集合)

简介: 上手Python之set(集合)

为什么使用集合


我们目前接触到了列表、元组、字符串三个数据容器了。基本满足大多数的使用场景。 为何又需要学习新的集合类型呢?


通过特性来分析:


列表可修改、支持重复元素且有序


元组、字符串不可修改、支持重复元素且有序


有没有看出一些局限?


局限就在于:它们都支持重复元素。


如果场景需要对内容做去重处理,列表、元组、字符串就不方便了。


而集合,最主要的特点就是:不支持元素的重复(自带去重功能)、并且内容无序


集合的定义


基本语法:


359eaee14f884946b2fad8aebb9d3705.png


和列表、元组、字符串等定义基本相同:

列表使用:[]

元组使用:()

字符串使用:""

集合使用:{}

aa4033acc17949938a31e54100ff35af.png


41b65df3e5e64d5f9696f5d4c58da6bb.png


结果中可见:

去重且无序

因为要对元素做去重处理

所以无法保证顺序和创建的时候一致

集合的常用操作 - 修改


首先,因为集合是无序的,所以集合不支持:下标索引访问

但是集合和列表一样,是允许修改的,所以我们来看看集合的修改方法。

添加新元素    

语法:集合.add(元素)。将指定元素,添加到集合内      

结果:集合本身被修改,添加了新元素


d520ebbb61ca46c783047629c5be7487.png

移除元素      

语法:集合.remove(元素),将指定元素,从集合内移除      

结果:集合本身被修改,移除了元素


76d2b92211894d07973a94290d3a6e39.png


从集合中随机取出元素      

语法:集合.pop(),功能,从集合中随机取出一个元素      

结果:会得到一个元素的结果。同时集合本身被修改,元素被移除


52f78c9734c34fa0bbc3204abae3b0f3.png

清空集合      

语法:集合.clear(),功能,清空集合      

结果:集合本身被清空


140826a405004953bedade14f5f95645.png

取出2个集合的差集      

语法:集合1.difference(集合2)

功能:取出集合1和集合2的差集(集合1有而集合2没有的)      

结果:得到一个新集合,集合1和集合2不变

7849059a41844ec7a0909fe5f656bc07.png


消除2个集合的差集      

语法:集合1.difference_update(集合2)      

功能:对比集合1和集合2,在集合1内,删除和集合2相同的元素。      

结果:集合1被修改,集合2不变


d9a30b0839be424c95dc204b7c94d6bc.png

2个集合合并      

语法:集合1.union(集合2)    

功能:将集合1和集合2组合成新集合      

结果:得到新集合,集合1和集合2不变

0f1051ad484941d6bb512fcf208583b5.png


集合的常用操作 - 集合长度

查看集合的元素数量      

语法:len(集合)    

功能:统计集合内有多少元素    

结果:得到一个整数结果


040cf707313244a08e2f5c75d0d5e864.png

集合的常用操作 - for循环遍历

集合同样支持使用for循环遍历

28309a16f7754506aac2ee399e301a77.png


要注意:集合不支持下标索引,所以也就不支持使用while循环。


image.png



相关文章
|
3月前
|
安全 网络安全 文件存储
思科设备巡检命令Python脚本大集合
【10月更文挑战第18天】
107 1
思科设备巡检命令Python脚本大集合
|
3月前
|
存储 NoSQL 关系型数据库
Redis 集合(Set)
10月更文挑战第17天
50 5
|
3月前
|
算法 Java 数据处理
从HashSet到TreeSet,Java集合框架中的Set接口及其实现类以其“不重复性”要求,彻底改变了处理唯一性数据的方式。
从HashSet到TreeSet,Java集合框架中的Set接口及其实现类以其“不重复性”要求,彻底改变了处理唯一性数据的方式。HashSet基于哈希表实现,提供高效的元素操作;TreeSet则通过红黑树实现元素的自然排序,适合需要有序访问的场景。本文通过示例代码详细介绍了两者的特性和应用场景。
58 6
|
3月前
|
存储 Java 数据处理
Java Set接口凭借其独特的“不重复”特性,在集合框架中占据重要地位
【10月更文挑战第16天】Java Set接口凭借其独特的“不重复”特性,在集合框架中占据重要地位。本文通过快速去重和高效查找两个案例,展示了Set如何简化数据处理流程,提升代码效率。使用HashSet可轻松实现数据去重,而contains方法则提供了快速查找的功能,彰显了Set在处理大量数据时的优势。
42 2
|
3月前
|
存储 算法 Java
Java Set因其“无重复”特性在集合框架中独树一帜
【10月更文挑战第14天】Java Set因其“无重复”特性在集合框架中独树一帜。本文深入解析Set接口及其主要实现类(如HashSet、TreeSet)如何通过特定的数据结构(哈希表、红黑树)确保元素唯一性,并提供最佳实践建议,包括选择合适的Set实现类和正确实现自定义对象的`hashCode()`与`equals()`方法。
41 3
|
2月前
set集合
HashSet(无序,唯一): 基于 HashMap 实现的,底层采用 HashMap 来保存元素。 LinkedHashSet: LinkedHashSet 是 HashSet 的子类,并且其内部是通过 LinkedHashMap 来实现的。 TreeSet(有序,唯一): 红黑树(自平衡的排序二叉树)。
|
2月前
|
存储 Java
判断一个元素是否在 Java 中的 Set 集合中
【10月更文挑战第30天】使用`contains()`方法可以方便快捷地判断一个元素是否在Java中的`Set`集合中,但对于自定义对象,需要注意重写`equals()`方法以确保正确的判断结果,同时根据具体的性能需求选择合适的`Set`实现类。
|
2月前
|
存储 Java 开发者
在 Java 中,如何遍历一个 Set 集合?
【10月更文挑战第30天】开发者可以根据具体的需求和代码风格选择合适的遍历方式。增强for循环简洁直观,适用于大多数简单的遍历场景;迭代器则更加灵活,可在遍历过程中进行更多复杂的操作;而Lambda表达式和`forEach`方法则提供了一种更简洁的函数式编程风格的遍历方式。
|
2月前
|
Java 开发者
从 Java 中的 Set 集合中删除元素
【10月更文挑战第30天】
|
3月前
|
存储 Java 数据处理
Set 是 Java 集合框架中的一个接口,不包含重复元素且不保证元素顺序。
【10月更文挑战第16天】Java Set:无序之美,不重复之魅!Set 是 Java 集合框架中的一个接口,不包含重复元素且不保证元素顺序。通过 hashCode() 和 equals() 方法实现唯一性,适用于需要唯一性约束的数据处理。示例代码展示了如何使用 HashSet 添加和遍历元素,体现了 Set 的高效性和简洁性。
55 4
下一篇
开通oss服务