【人生苦短,我学 Python】(5)集合数据类型(set、frozenset)

2023-12-11 12:45

本文主要是介绍【人生苦短,我学 Python】(5)集合数据类型(set、frozenset),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 简述 / 前言
  • 1. set数据类型(集合)
    • 1.1 创建集合对象
      • 1.1.1 set
      • 1.1.2 frozenset
    • 1.2 访问集合元素
    • 1.3 集合的长度、最大值、最小值、元素和
    • 1.4 集合支持的运算
    • 1.5 集合对象方法
  • 文章传送门

简述 / 前言

前面主要了解了 Python 的语言基础,现在我们来了解 Python 给我们提供了哪些数据类型,以及如何使用这些数据类型。

  • Python语言中,一切皆为对象,而每个对象都属于某个数据类型;
  • Python的数据类型包括内置的数据类型、模块中定义的数据类型和用户自定义的类型;
    • 数值数据类型:int、bool、float、complex;
    • 序列数据类型:不可变(str、tuple、bytes)和可变(list、bytearray);
    • 集合数据类型:set、frozenset;
    • 字典数据类型:dict。例如:{1: “one”, 2: “two”};;
    • NoneType、NotImplementedType和EllipsisType。

上一篇文章我们介绍了序列数据类型(str、tuple、list、bytes和bytearray),这篇我们介绍集合数据类型(set、frozenset)

1. set数据类型(集合)

  1. 集合的特点:
    • 集合是无序的,不能通过数字进行索引。
    • 集合的元素不能重复出现
  2. 集合的应用:
    • 去除列表中的重复元素
    • 求两个列表的相同元素(交集)
    • 求两个列表的不同元素(差集)
  3. 集合可分为两类:
    • 可变集合(set):可以添加和删除元素
    • 不可变集合(frozenset):不允许添加和删除元素

集合可以通过 set() 或者 {} 方法创建!

1.1 创建集合对象

1.1.1 set

>>> s1 = set('hello')					# set()方法
>>> s1
{'e', 'o', 'l', 'h'}
>>> type(s1)
<class 'set'>
>>> s2 = {'h', 'e', 'l', 'l', 'o'}		# {}方法
>>> s2
{'e', 'o', 'l', 'h'}
>>> type(s2)
<class 'set'>
>>> s3 = set(['h', 'e', 'l', 'l', 'o'])	# set()方法【如果要创建多个元素时用列表(list)括起来】
>>> s3
{'e', 'o', 'l', 'h'}
>>> type(s3)
<class 'set'>
>>> s4 = {}		# 虽然{}可以创建集合,但是空的{}不代表集合,而是之后会介绍的字典(dict)!!!
>>> s4
{}
>>> type(s4)	# 类型是字典,不是集合
<class 'dict'>
>>> s5 = set()	# 空集合
>>> s5
set()
>>> type(s5)
<class 'set'>
>>> s6 = set('h', 'e', 'l', 'l', 'o')	# 【易错点】创建多元素集合时要用列表括起来,即:set(['h', 'e', 'l', 'l', 'o'])
Traceback (most recent call last):File "<stdin>", line 1, in <module>
TypeError: set expected at most 1 argument, got 5

1.1.2 frozenset

通过类型构造器:frozenset() 创建集合。

  • 创建后的集合不能改变集合元素。

例如,创建一个星期的英文缩写的不可变集合:

>>> s7 = frozenset(('MON','TUE','WED','THU','FRI','SAT','SUN'))
>>> s7
frozenset({'SAT', 'FRI', 'TUE', 'SUN', 'WED', 'MON', 'THU'})
>>> type(s7)
<class 'frozenset'>

1.2 访问集合元素

由于集合本身是无序的,所以不能为集合创建索引或切片操作,只能循环遍历或使用 in、not in 来访问或判断集合元素。

>>> 'WED' in s7
True
>>> 'WWW' in s7
False
>>> for day in s7:
...     print(day, end=" ")
...
SAT FRI TUE SUN WED MON THU

1.3 集合的长度、最大值、最小值、元素和

通过内置函数 len()max()min()sum(),可以获取集合的长度、元素最大值、元素最小值、元素之和。

>>> s8 = {1,2,3,4,5,6,7,8,9}
>>> len(s8)
9
>>> max(s8)
9
>>> min(s8)
1
>>> sum(s8)
45

1.4 集合支持的运算

运算含意
x in <集合>检测x是否在集合中
s1|s2并集
s1&s2交集
s1-s2差集
s1^s2异或集,求s1与s2中相异元素
s1|=s2将s2的元素并入s1
s1==s2判断集合是否相等
s1<=s2判断s1是否是s2的子集
s1<s2判断s1是否是s2的真子集
s1>=s2判断s1是否是s2的超集
s1>s2判断s1是否是s2的真超集
>>> s1 = {1, 2, 3, 4}
>>> s1
{1, 2, 3, 4}
>>> s2 = {3, 5, 6}
>>> s2
{3, 5, 6}
>>> s3 = {2, 3}
>>> s3
{2, 3}
>>> 3 in s1		# 3在集合s1中
True
>>> 5 in s1		# 5不在集合s1中
False
>>> s1 | s2		# s1和s2的并集
{1, 2, 3, 4, 5, 6}
>>> s1 & s2		# s1和s2的交集
{3}
>>> s1 - s2		# s1和s2的差集
{1, 2, 4}
>>> s1 ^ s2		# s1和s2的异或集
{1, 2, 4, 5, 6}
>>> s1			# 上述集合运算不改变原集合
{1, 2, 3, 4}
>>> s1 |= s2	# 将s2并入到s1中
>>> s1			# 此并入操作会修改原集合
{1, 2, 3, 4, 5, 6}
>>> s1 == s2	# 判断两个集合是否相等
False
>>> s2 <= s1	# s2是s1的子集
True
>>> s2 < s1		# s2是s1的真子集
True
>>> s1 >= s2	# s1是s2的超集
True
>>> s1 > s2		# s1是s2的真超集
True

:判断两个集合是否相等,只需判断其中包含的集合元素是否一致,与顺序无关

1.5 集合对象方法

方法含意
s1.union(s2 )s1|s2,返回一个新的集合对象
s1.difference(s2)s1-s2,返回一个新的集合对象
s1.intersection(s2)s1&s2,返回一个新的集合对象
s1.issubset(s2)s1<=s2
s1.issuperset(s2)s1>=s2
s1.update(s2)将s2的元素并入s1【*】
s1.add (x)增加元素x到s1【*】
s1.remove(x)从s1移除x,x不存在报错【*】
s1.clear ()清空s1【*】
s1.copy()复制s1,返回一个新的集合对象

:打星号*的方法是set集合独有的方法,不打星号的方法是两种集合都有的方法。

文章传送门

上一篇文章:【人生苦短,我学 Python】(4)Python 常用内置数据类型 II —— 序列数据类型(str、tuple、list、bytes和bytearray)
下一篇文章:

这篇关于【人生苦短,我学 Python】(5)集合数据类型(set、frozenset)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/480733

相关文章

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

uva 11178 计算集合模板题

题意: 求三角形行三个角三等分点射线交出的内三角形坐标。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#include <stack>#include <vector>#include <

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

poj 3050 dfs + set的妙用

题意: 给一个5x5的矩阵,求由多少个由连续6个元素组成的不一样的字符的个数。 解析: dfs + set去重搞定。 代码: #include <iostream>#include <cstdio>#include <set>#include <cstdlib>#include <algorithm>#include <cstring>#include <cm

nudepy,一个有趣的 Python 库!

更多资料获取 📚 个人网站:ipengtao.com 大家好,今天为大家分享一个有趣的 Python 库 - nudepy。 Github地址:https://github.com/hhatto/nude.py 在图像处理和计算机视觉应用中,检测图像中的不适当内容(例如裸露图像)是一个重要的任务。nudepy 是一个基于 Python 的库,专门用于检测图像中的不适当内容。该

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip

HTML提交表单给python

python 代码 from flask import Flask, request, render_template, redirect, url_forapp = Flask(__name__)@app.route('/')def form():# 渲染表单页面return render_template('./index.html')@app.route('/submit_form',

Collection List Set Map的区别和联系

Collection List Set Map的区别和联系 这些都代表了Java中的集合,这里主要从其元素是否有序,是否可重复来进行区别记忆,以便恰当地使用,当然还存在同步方面的差异,见上一篇相关文章。 有序否 允许元素重复否 Collection 否 是 List 是 是 Set AbstractSet 否