生命在于学习——Python人工智能原理(2.3.3)

在这里插入图片描述

三、Python的数据类型

3.2 Python的组合数据类型

特点:表示多个元素的组合,可以包含不同类型的元素,甚至是其他的组合数据类型。
在内存中通常需要额外的空间来存储元素间的关系。
组合数据类型能够将多个同类型或不同类型的数据组织起来,通过单一的表示并根据数据之间的关系,可将它们分为3类:序列类型、集合类型、映射类型。
序列类型是一个元素向量,元素之间存在先后关系,通过序号访问,元素之间不排他。
集合类型是一个元素的集合,元素之间无序,集合中每个元素值都具有唯一性,集合类型就像一个带有标签的容器。
映射类型是键-值 数据项的集合,每个元素都是一个键-值对,表示为(key,value),其中key具有唯一性。映射类型就像一个标签收纳盒,给每个数据贴上唯一的标签,可以通过具有特定意义的名字或记号来获得数据。
Python中有很多数据类型都是序列类型,其中比较重要的是字符串、元组、列表。
元组是包含0个或多个数据项的不可变序列类型,即元祖一旦生成,任何数据项都不可替换或删除。
列表则是一个可以修改数据项的序列类型,使用非常灵活。
字符串可以看成一个单字符的有序组合,属于序列类型,同时也是一种基本数据类型。
序列类型都使用相同的索引体系,支持双向索引。
序列类型通用操作符与函数:
在这里插入图片描述

3.2.1 元组类型

元组是Python中的一种有序、不可变、可迭代的数据类型。元组与列表相似,但主要区别在于元组的不可变性。一旦创建,元组的内容无法修改。
元组类型特点:

  1. 有序性:元组中的元素是按照其插入顺序有序排列的。
  2. 不可变性:元组的元素不可修改,包括增删修等操作。
  3. 可迭代性:可以通过循环遍历元组中的元素。
  4. 多数据类型:元组中的元素可以是不同的数据类型,包括数字、字符串、其他元祖等。
  5. 创建元组:Python可以通过两种方式创建元组,一种是用tuple()函数创建,tuple()函数中的参数是一个可迭代的数据,若没有传入参数,则创建空元祖。另一种是直接用圆括号包含多个用逗号隔开的元素创建元组,非空元组的括号可以忽略。
# 创建一个元组  
my_tuple = (1, 2, 3, 4, 5)  
  
# 访问元组中的元素  
first_element = my_tuple[0]  # 输出 1  
  
# 遍历元组  
for element in my_tuple:  
    print(element)  
  
# 尝试修改元组元素(会报错)  
# my_tuple[0] = 10  # 这行代码会抛出 TypeError 异常  
  
# 元组可以包含不同类型的元素  
mixed_tuple = (1, 'two', 3.0, [4, 5, 6])  # 注意这里虽然有一个列表,但元组本身是不可变的

3.2.2 列表类型

列表是一个可变的序列类型,可以修改、添加、删除其中的元素。
列表使用方括号 [] 来表示。
列表是 Python 中最常用的数据结构之一,可以包含任何类型的元素,且支持元素间的各种操作(如排序、查找等)。
由于列表是可变的,所以它在内存中的表示相对于元组来说更加复杂,并且在需要固定值的场合中不太适合使用。

当然,Python中的列表操作确实非常丰富。以下是对列表操作的一个详细归纳,包括基本的和高级的操作,并辅以代码示例:

一、基本列表操作
创建列表
使用方括号 [] 包围元素,元素之间用逗号 , 分隔。
python
my_list = [1, 2, 3, 4, 5]
访问列表中的元素
通过索引访问,索引从0开始。
python
first_element = my_list[0]  # 访问第一个元素
更新列表
直接对索引位置赋值以更新元素。
python
my_list[0] = 10  # 更新第一个元素为10
删除列表元素
使用 del 语句删除指定索引的元素。
使用 remove() 方法删除指定值的元素(第一个匹配的)。
使用 pop() 方法删除指定索引的元素(并返回该元素)。
python
del my_list[0]  # 删除第一个元素  
my_list.remove(2)  # 删除第一个值为2的元素  
popped_element = my_list.pop(1)  # 删除索引为1的元素,并返回它
列表拼接与截取
使用 + 运算符拼接两个列表。
使用切片 [start:stop:step] 截取列表的一部分。
python
new_list = my_list + [6, 7, 8]  # 拼接列表  
sliced_list = my_list[1:4]  # 截取索引1到3(不包含)的元素
二、高级列表操作
列表函数与方法
len(list):返回列表长度。
min(list)max(list):返回列表中的最小值和最大值。
list(iterable):将可迭代对象转换为列表。
list.append(element):在列表末尾添加元素。
list.extend(iterable):将可迭代对象的元素添加到列表末尾。
list.insert(index, element):在指定索引处插入元素。
list.index(element, [start, [stop]]):返回元素在列表中首次出现的索引。
list.count(element):返回元素在列表中出现的次数。
list.sort([key[, reverse=True|False]]):对列表进行排序(会改变原列表)。
sorted(iterable, key=None, reverse=False):返回排序后的新列表(不会改变原列表)。
列表推导式
使用列表推导式可以简洁地创建列表。
python
squares = [x**2 for x in range(1, 6)]  # 创建包含1到5的平方的列表
列表嵌套
列表可以包含其他列表,形成嵌套列表。
python
matrix = [[1, 2, 3], [4, 5, 6], [7, 8, 9]]  # 创建一个3x3的矩阵
列表比较
列表之间可以使用比较运算符(如 ==, !=, <, >, <=, >=)进行比较。
遍历列表
使用 for 循环遍历列表中的每个元素。
使用 enumerate() 函数在遍历时同时获取元素和索引。
列表元素的排序与查找
如前所述,可以使用 sort() 方法或 sorted() 函数对列表进行排序。
使用 index() 方法查找元素在列表中的索引。
三、示例代码
python
# 示例:使用列表的基本和高级操作  
my_list = [3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5]  
  
# 访问和更新元素  
print(my_list[0])  # 输出: 3  
my_list[0] = 0  
  
# 删除元素  
my_list.remove(1)  
  
# 列表排序  
my_list.sort()  
print(my_list)  # 输出: [0,

3.2.3 集合类型

集合(Set)是Python中的一种基本数据结构,用于存储多个不重复的元素。与列表和元组不同,集合中的元素是无序的,即集合中的元素没有固定的位置。集合中的元素必须是可哈希的,即不可变类型,如数字、字符串、元组等。

在Python中,可以使用两种方式来创建集合:

使用大括号 {},但需要注意,如果大括号内没有元素,则创建的是一个空字典,而不是空集合。因此,要创建一个空集合,应使用 set() 函数。

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

集合特点

无序性:集合中的元素没有固定的顺序,即集合不支持通过索引来访问元素。
唯一性:集合中的元素是唯一的,即集合中的每个元素都是独一无二的。如果试图向集合中添加已存在的元素,集合不会变化。
可变性:集合是可变的,即可以向集合中添加、删除或修改元素。
支持多种运算:集合支持常见的集合运算,如并集、交集、差集和对称差集等。
支持快速成员关系测试:集合可以很快地进行成员关系测试,即判断一些元素是否出现在集合中。
元素类型的限制:集合中的元素必须是可哈希的,即元素必须是不可变的,如数字、字符串、元组等。不可哈希的类型,如列表和字典,不能作为集合的元素。

集合操作

添加元素:使用 add() 方法向集合中添加一个元素,或使用 update() 方法添加多个元素。
python
my_set.add(6)  # 添加单个元素  
my_set.update([7, 8, 9])  # 添加多个元素
删除元素:使用 remove() 方法删除指定值的元素(如果元素不存在,会抛出异常),或使用 discard() 方法删除指定值的元素(如果元素不存在,不会抛出异常)。另外,可以使用 pop() 方法随机删除并返回一个元素(如果集合为空,会抛出异常)。
python
my_set.remove(5)  # 删除元素5  
my_set.discard(6)  # 尝试删除元素6,如果不存在则不报错  
removed_element = my_set.pop()  # 随机删除并返回一个元素
集合运算:
并集:使用 | 运算符或 union() 方法计算两个集合的并集。
交集:使用 & 运算符或 intersection() 方法计算两个集合的交集。
差集:使用 - 运算符或 difference() 方法计算两个集合的差集(第一个集合有而第二个集合没有的元素)。
对称差集:使用 ^ 运算符或 symmetric_difference() 方法计算两个集合的对称差集(两个集合中不同时存在的元素)。
python
set1 = {1, 2, 3}  
set2 = {2, 3, 4}  
  
union_set = set1 | set2  # {1, 2, 3, 4}  
intersection_set = set1 & set2  # {2, 3}  
difference_set = set1 - set2  # {1}  
symmetric_difference_set = set1 ^ set2  # {1, 4}
判断元素是否存在:使用 in 关键字判断一个元素是否存在于集合中。
python
if 1 in my_set:  
    print("1存在于集合中")
其他操作:集合还支持其他操作,如 clear() 方法清空集合,copy() 方法复制集合,isdisjoint() 方法判断两个集合是否没有交集等。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/756889.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

MAS0902量产工具分享,MAS0902A开卡教程,MAS0901量产工具下载

MAS0902和MAS1102都是基于SATA3.2技术开发的DRAM-less SSD控制芯片&#xff0c;简单来说就是SATA协议无缓存主控。下面是我摸索的麦光黑金300 240G SSD开卡修复简易教程&#xff0c;也就是MAS0902量产过程&#xff1a; 注意&#xff1a;开卡转接线必须要用ASM1153E或JMS578主控…

Linux部署Java项目至云服务器

文章目录 1.服务器环境2.发布部署过程2.1 执行SQL脚本2.2 修改代码中数据源的配置2.3 修改配置中的日志级别与日志文件路径2.4 打包Java程序2.5 上传到服务器2.6 后台运行2.7 服务器开放对应的端口2.8 访问验证 1.服务器环境 要将我们的项目部署到云服务器上我们就需要先有一个…

独一无二的设计模式——单例模式(python实现)

1. 引言 大家好&#xff0c;今天我们来聊聊设计模式中的“独一无二”——单例模式。想象一下&#xff0c;我们在开发一个复杂的软件系统&#xff0c;需要一个全局唯一的配置管理器&#xff0c;或者一个统一的日志记录器&#xff1b;如果每次使用这些功能都要创建新的实例&…

SpringCloud中复制模块然后粘贴,文件图标缺少蓝色方块

再maven中点击&#xff0b;号&#xff0c;把当前pom文件交给maven管理即可

【UE 网络】RPC远程过程调用 入门篇

目录 0 引言1 RPC基本概念1.1 定义1.2 分类 2 RPC的使用2.1 Client RPC2.2 Server RPC2.3 Multicast RPC &#x1f64b;‍♂️ 作者&#xff1a;海码007&#x1f4dc; 专栏&#xff1a;UE虚幻引擎专栏&#x1f4a5; 标题&#xff1a;【UE 网络】RPC远程过程调用 入门篇❣️ 寄语…

汇聚荣拼多多运营好吗?

在当前电商行业竞争激烈的背景下&#xff0c;拼多多凭借其独特的商业模式和市场定位迅速崛起&#xff0c;成为众多商家和品牌争相入驻的平台。对于“汇聚荣拼多多运营好吗?”这一问题&#xff0c;答案是肯定的。拼多多不仅提供了一个广阔的市场空间&#xff0c;还通过其创新的…

如何在 SQL 中删除一条记录?

如何在 SQL 中删除一条记录&#xff1f; 在 SQL 中&#xff0c;您可以使用DELETE查询和WHERE子句删除表中的一条记录。在本文中&#xff0c;我将向您介绍如何使用DELETE查询和WHERE子句删除记录。我还将向您展示如何一次从表中删除多条记录 如何在 SQL 中使用 DELETE 这是使…

【多维动态规划】Leetcode 97. 交错字符串【中等】

交错字符串 给定三个字符串 s1、s2、s3&#xff0c;请你帮忙验证 s3 是否是由 s1 和 s2 交错 组成的。 两个字符串 s 和 t 交错 的定义与过程如下&#xff0c;其中每个字符串都会被分割成若干 非空 子字符串 子字符串 是字符串中连续的 非空 字符序列。 s s1 s2 … snt…

40V 60V 80V 100V 400V高压LDO三端稳压器选择,技术参数

40V 60V 80V 100V 400V高压LDO三端稳压器选择,技术参数

网页如何快速被收录?

其实就是要要吸引搜索引擎爬虫更快地抓取你的网页&#xff0c;想让爬虫爬取网页&#xff0c;首要做的自然是创建并提交站点地图。站点地图是搜索引擎了解你网站结构的重要工具。它可以帮助爬虫更快地发现和抓取你网站上的所有重要页面。通过Google Search Console提交站点地图&…

Webpack: 构建微前端应用

Module Federation 通常译作“模块联邦”&#xff0c;是 Webpack 5 新引入的一种远程模块动态加载、运行技术。MF 允许我们将原本单个巨大应用按我们理想的方式拆分成多个体积更小、职责更内聚的小应用形式&#xff0c;理想情况下各个应用能够实现独立部署、独立开发(不同应用甚…

Unity保存玩家的数据到文件中(Unity的二进制序列化)

文章目录 文章运行环境什么是二进制序列化读写文件构造函数 自定义二进制序列化 文章运行环境 Unity2022 什么是二进制序列化 Unity中的二进制序列化是一种将游戏对象或数据结构转换为二进制格式的过程&#xff0c;以便于存储或网络传输。这使数据能够以高效的方式保存&…

鸿蒙开发设备管理:【@ohos.geolocation (位置服务)】

位置服务 说明&#xff1a; 本模块首批接口从API version 7开始支持。后续版本的新增接口&#xff0c;采用上角标单独标记接口的起始版本。 导入模块 import geolocation from ohos.geolocation;geolocation.on(‘locationChange’) on(type: ‘locationChange’, request: L…

容器进程

一、容器进程和宿主机进程的关系 容器在进程空间上和宿主机是隔离的&#xff0c;每创建一个容器&#xff0c;该容器都有一个独属的进程空间简称PID NameSpace。但是容器本质也是一个进程&#xff0c;自然是由其父进程创建的&#xff0c;这个可以使用ps aux命令验证。 | 容器视…

Leetcode - 133双周赛

目录 一&#xff0c;3190. 使所有元素都可以被 3 整除的最少操作数 二&#xff0c;3191. 使二进制数组全部等于 1 的最少操作次数 I 三&#xff0c;3192. 使二进制数组全部等于 1 的最少操作次数 II 四&#xff0c;3193. 统计逆序对的数目 一&#xff0c;3190. 使所有元素都…

冯雷老师:618大退货事件分析

近日冯雷老师受邀为某头部电商36名高管进行培训&#xff0c;其中聊到了今年618退货潮的问题。以下内容整理自冯雷老师的部分授课内容。 一、引言 随着电子商务的蓬勃发展&#xff0c;每年的618大促已成为消费者和商家共同关注的焦点。然而&#xff0c;在销售额不断攀升的同时…

MySQL之如何分析慢查询

1、一个SQL语句执行很慢&#xff0c;如何分析&#xff1f; 可使用“explain”或者“desc”命令获取MySQL如何执行select语句的信息。 语法&#xff1a;直接在select语句前加关键字 explain或desc explain select job_desc from xxl_job_info where id 1; 2、执行计划中五个重…

Python的一个非常cool的库Gradio

Python的一个非常cool的库Gradio Gradio简介 Gradio是一个开源的Python库&#xff0c;它允许用户为机器学习模型、API或任何Python函数快速构建演示或Web应用程序。Gradio的目标是简化AI模型的可视化和交互过程&#xff0c;使得即使没有前端开发背景的用户也能够轻松地创建和…

装载问题(回溯法)

#include<iostream> using namespace std; int n;//货物的数量 int c;//轮船的总的载重量 int cw;//轮船当前的载重量 int r;//货物的总重量 int w[1000];//n个货物各自的重量 int x[1000];//当前最优解 int bestx[1000];//最优解 int bestw;//货物的最优载重量 void Bac…

os实训课程模拟考试(大题复习)

目录 一、Linux操作系统 &#xff08;1&#xff09;第1关&#xff1a;Linux初体验 &#xff08;2&#xff09;第2关&#xff1a;Linux常用命令 &#xff08;3&#xff09;第3关&#xff1a;Linux 查询命令帮助语句 二、Linux之进程管理—&#xff08;重点&#xff09; &…