元组(Tuple)是Python中一种不可变的序列类型,用于存储多个有序元素。与列表(List)类似,但元组一旦创建后不能修改(不可添加、删除或修改元素),这使得它在安全性、性能优化和特定场景(如字典键)中具有独特优势。

创建元组

创建空元组

# 空元组
tuple_data = () 
print(f"tuple_data = {tuple_data}")

tuple_data = ()

创建非空元组,数据类型统一

# 非空元组
tuple_data = (1,2,3,6,9,4) 
print(f"tuple_data = {tuple_data}")

tuple_data = (1, 2, 3, 6, 9, 4)

创建非空元组,数据类型不统一

# 非空元组
tuple_data = (1,2,3,"小明","phyton") 
print(f"tuple_data = {tuple_data}")

tuple_data = (1, 2, 3, ‘小明’, ‘phyton’)

元组中只包含一个元素时,需要在元素后面添加逗号 , ,否则括号会被当作运算符使用。

tuple_data = (36) 
print(f"tuple_data = {tuple_data}")tuple_data2 = (36,)
print(f"tuple_data2 = {tuple_data2}")

tuple_data = 36
tuple_data = (36,)

访问元组元素

元组可以使用下标索引来访问元组中指定位置的元素,既可以正向访问,也可以反向访问。

正向读取,索引从0 ~ n-1,up[0](第一个元素)。

tuple_data = (1,2,3,"小明","phyton") 
result = tuple_data[0] # 使用索引访问元素
print(f"tuple_data = {tuple_data}\ntuple_data[0] = {result}")

tuple_data = (1, 2, 3, ‘小明’, ‘phyton’)
tuple_data[0] = 1

反向读取,索引从-1 ~ -n,tup[-1](最后一个元素)。

tuple_data = (1,2,3,"小明","phyton") 
result = tuple_data[-2] # 使用索引访问元素
print(f"tuple_data = {tuple_data}\ntuple_data[0] = {result}")

tuple_data = (1, 2, 3, ‘小明’, ‘phyton’)
tuple_data[0] = 小明

切片,即使用索引,也可以截取索引中的一段元素,以获取新元组,或反转元组,如tup[1:3](索引1到2的元素,返回新元组),tup[::-1](反转元组)。

tuple_data = (1,2,3,"小明","phyton") 
result = tuple_data[1:4] # 使用索引访问元素,生成新数组
print(f"tuple_data = {tuple_data}\ntuple_data[0] = {result}")

tuple_data = (1, 2, 3, ‘小明’, ‘phyton’)
tuple_data[0] = (2, 3, ‘小明’)

tuple_data = (1,2,3,"小明","phyton") 
result = tuple_data[::-1] # 反转元组
print(f"tuple_data = {tuple_data}\ntuple_data[0] = {result}")

tuple_data = (1, 2, 3, ‘小明’, ‘phyton’)
tuple_data[0] = (‘phyton’, ‘小明’, 3, 2, 1)

遍历,支持for循环直接遍历元素。

tuple_data = (1,2,3,"小明","phyton") 
print(f"tuple_data = {tuple_data}\n")
for i in tuple_data:print(i)

tuple_data = (1, 2, 3, ‘小明’, ‘phyton’)

1
2
3
小明
phyton

修改元组

组中的元素值是不允许修改的,但可以使用”+“对元组进行连接组合

tuple_data = (1,2,3,"小明","phyton")
tuple_data2 = (36,)
result = tuple_data + tuple_data2
print(f"tuple_data = {tuple_data} \n tuple_data2 = {tuple_data2} \n tuple_data + tuple_data2 = {result}")

tuple_data = (1, 2, 3, ‘小明’, ‘phyton’)
tuple_data2 = (36,)
tuple_data + tuple_data2 = (1, 2, 3, ‘小明’, ‘phyton’, 36)

删除元组

元组中的元素值是不允许删除的,但我们可以使用"del"语句来删除整个元组。

tuple_data = (1,2,3,"小明","phyton")
print(f"tuple_data = {tuple_data}\n")del tuple_data
print(f"tuple_data = {tuple_data}") # 元组被删除后,输出变量会有异常信息

tuple_data = (1, 2, 3, ‘小明’, ‘phyton’)

Traceback (most recent call last):
File “.code.tio”, line 4, in
print(f"tuple_data = {tuple_data}")
NameError: name ‘tuple_data’ is not defined

元组运算符

使用 len(tuple) 方法,计算元组元素个数

tuple_data = (1,2,3,"小明","phyton")
result = len(tuple_data)
print(f"tuple_data = {tuple_data}\n元素数量:{result}")

tuple_data = (1, 2, 3, ‘小明’, ‘phyton’)
元素数量:5

使用 tuple* n 方法,复制元组

注:n为整数

tuple_data = (1,2,3,"小明","phyton")
result = tuple_data * 2
print(f"tuple_data = {tuple_data}\n复制元组:{result}")

tuple_data = (1, 2, 3, ‘小明’, ‘phyton’)
复制元组:(1, 2, 3, ‘小明’, ‘phyton’, 1, 2, 3, ‘小明’, ‘phyton’)

检查元素是否存在

使用in方法,判断元素是否存在于元组

tuple_data = (1,2,3,"小明","phyton")
result = 10 in tuple_data
print(f"tuple_data = {tuple_data}\n10是否存在:{result}")

tuple_data = (1, 2, 3, ‘小明’, ‘phyton’)
10是否存在:False

使用not in方法,判断元素是否不存在于元绷

tuple_data = (1,2,3,"小明","phyton")
result = 10 not in tuple_data
print(f"tuple_data = {tuple_data}\n10是否不存在:{result}")

tuple_data = (1, 2, 3, ‘小明’, ‘phyton’)
10是否不存在:True

使用 count(元素) 方法,统计元素在元组中出现的次数

tuple_data = (1,2,3,99,1)
result = tuple_data.count(1)
print(f"tuple_data = {tuple_data}\n元素1出现次数:{result}")

tuple_data = (1, 2, 3, 99, 1)
元素1出现次数:2

使用 max(元组) 方法,返回元组中最大值

注:数据类型保持一致。

tuple_data = (1,2,3,99,-10)
result = max(tuple_data)
print(f"tuple_data = {tuple_data}\n最大值:{result}")

tuple_data = (1, 2, 3, 99, -10)
最大值:99

使用 min(元组) 方法,返回元组中最小值

注:数据类型保持一致。

tuple_data = (1,2,3,99,-10)
result = min(tuple_data)
print(f"tuple_data = {tuple_data}\n最小值:{result}")

tuple_data = (1, 2, 3, 99, -10)
最小值:-10

使用 tuple(列表) 方法,将列表转元组

list_data = [1,2,3,99,-10]
result = tuple(list_data)
print(f"list_data = {list_data}\n列表转元组:{result}")

list_data = [1, 2, 3, 99, -10]
列表转元组:(1, 2, 3, 99, -10)

使用 index(x) 方法,返回第一个x元素的索引(不存在时抛出ValueError)。

tuple_data = (1,2,3,99,1)
result = tuple_data.index(2)
print(f"tuple_data = {tuple_data}\n元素2出现位置:{result}")

tuple_data = (1, 2, 3, 99, 1)
元素2出现位置:1

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/diannao/98807.shtml
繁体地址,请注明出处:http://hk.pswp.cn/diannao/98807.shtml
英文地址,请注明出处:http://en.pswp.cn/diannao/98807.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

大数据毕业设计选题推荐-基于大数据的国家医用消耗选品采集数据可视化分析系统-Hadoop-Spark-数据可视化-BigData

✨作者主页:IT毕设梦工厂✨ 个人简介:曾从事计算机专业培训教学,擅长Java、Python、PHP、.NET、Node.js、GO、微信小程序、安卓Android等项目实战。接项目定制开发、代码讲解、答辩教学、文档编写、降重等。 ☑文末获取源码☑ 精彩专栏推荐⬇…

二次学习C语言补充2

文章目录表栈、队列、二叉树一、二叉树二、表栈三、队列链表一、单向链表二、循环链表、双向链表和双向循环链表预处理一、预处理二、宏定义文件文件操作补充本篇文章是对二次学习C语言12——文件操作 二次学习C语言14——预处理及模块化 二次学习C语言15——链表 二次学习C语言…

2.9Vue创建项目(组件)的补充

1.再创建和引入vue的选择2.VsCode插件 安装Vue自己搜索最新的3.style自己的作用域在一个组件中引入另一个文件的子组件,给当前组件设置样式,那么子组件的样式也会改变的。为了解决这个问题 我们在自己的style中设置一个属性4.另一种创建vue 的方式(主流…

算法高频题

刷题:LeetCode(Top 100-150题,至少刷两遍)。重点:链表、树、二分查找、动态规划、回溯、栈/队列。 每一个题型,前10个高频题 算法思考框架参考:算法题思维框架-CSDN博客 高频顺序参考网站&…

服务器安装 LDOPE(MODIS 数据处理工具)

目录下载方式1-(简单快捷)根据WRF-VPRM 需要打补丁下载方式2:(手动安装依赖)一、安装所需依赖库(4 个主库 2 个基础库)另- HDF-EOS 手动编译二、解压并安装 LDOPE参考下载方式1-(简…

克隆代币 + 捆绑开盘:多链环境下的低成本发币玩法

在加密世界,发币已经不再是“少数开发者的专利”。随着工具的普及,任何人都可以快速发行一个在加密世界,发币已经不再是“少数开发者的专利”。随着工具的普及,任何人都可以快速发行一个代币。但问题是:如何在保证低成…

数据结构中的 二叉树

1.前言 在 Java 中,树(Tree)是一种非线性数据结构,由节点(Node)组成,常见的线性表则是我们之前学过的顺序表、链表、栈、队列等等。每个节点包含数据和指向子节点的引用。树的常见实现方式包括二…

IntelliJ IDEA 启动项目时配置端口指南

🌟 一、为什么需要手动设置启动端口? 默认情况下,Spring Boot 应用会使用 8080 端口启动。但在以下场景中,我们必须自定义端口: 多个微服务同时运行,需避免端口冲突;团队协作开发,统…

spark sql之from_json函数

目录前言函数语法参数说明返回值案例案例1案例2前言 在Spark SQL中,from_json函数用于解析包含JSON字符串的列,并将其转换为Spark SQL的结构化类型(如struct、map或array) 函数语法 from_json(jsonStr, schema [, options])参数…

数据结构 之 【位图的简介】

目录 1.位图的引入 2.位图概念 3.位图的实现 3.1前提准备 3.2set 3.3reset 3.4test 4.位图的应用 1.位图的引入 给40亿个不重复的无符号整数,没排过序 再给一个无符号整数,如何快速判断这个无符号整数是否在 这40亿个数中 首先,一个…

[iOS] ViewController 的生命周期

文章目录前言一、UIViewController 生命周期有关函数二、UIViewController 中函数的执行顺序运行结果1.present和dismiss2.push和pop三、总结前言 UIViewController 是在 iOS 开发中一个非常重要的角色,他是 view 和 model 的桥梁,通过 UIViewControlle…

第30章 零售与电商AI应用

本章将深入探讨人工智能在零售与电商领域的革命性应用。我们将从智能推荐系统、动态定价、库存管理到创新的虚拟试衣间,全面解析AI如何重塑购物体验和商业运营效率,并为每个关键技术点提供代码实战,帮助你掌握将AI应用于真实商业场景的能力。…

QT通过QModbusRtuSerialMaster读写电子秤数据实例

一、电子称常用功能:称重、清零、去皮;电子秤的通讯方式:Modbus通信、串口通信。二、QT读写电子秤软件界面如下:三、核心代码如下:.pro项目文件代码:QT core gui serialbus serialport.h头文件代码#…

sqlmap常用命令

ZZHow(ZZHow1024) 一、扫描注入点 1.GET方法,给URL: #探测该url是否存在漏洞 python sqlmap.py -u "http://192.168.10.1/sqli/Less-1/?id1"#如果我们已经知道admin这里是注入点的话,可以在其后面加个*来让sqlmap对其注入 python …

JVM如何排查OOM

当JVM(Java虚拟机)出现OOM(OutOfMemoryError)时,可以按照以下步骤和方法,用于帮助定位和解决JVM中的OOM问题1.查看异常堆栈信息查看异常堆栈信息(StackTrace)是定位问题的关键。OOM异…

存算一体芯片生态评估:从三星PIM到知存科技WTM2101

点击 “AladdinEdu,同学们用得起的【H卡】算力平台”,注册即送-H卡级别算力,80G大显存,按量计费,灵活弹性,顶级配置,学生更享专属优惠。 引言:存算一体技术的崛起与意义 在传统冯诺…

[数据结构] 栈 · Stack

一.栈 stack 1.概念 栈 : 一种特殊的线性表 , 其只允许再固定的一段进行插入和删除元素操作 进行数据插入和删除操作的一段称为 栈顶 ; 另一端称为栈底栈中的数据元素遵循 先进后出 原则(LIFO)压栈 : 栈的插入操作叫做 进栈 或 压栈 或 入栈 , 入数据在栈顶出栈 : 栈的删除…

MySQL执行过程中如何选择最佳的执行路径

本篇文章介绍一个非常核心的数据库问题。MySQL 选择最佳执行路径(即“查询优化”)的过程是由其查询优化器(Query Optimizer) 完成的。 简单来说,优化器的目标是:在多种可能的执行方案中,选择一个…

【设计模式】从游戏角度开始了解设计模式 --- 抽象工厂模式

永远记住,你的存在是有意义的, 你很重要, 你是被爱着的, 而且你为这个世界带来了无可取代的东西。 -- 麦克西 《男孩、鼹鼠、狐狸和马》-- 从零开始了解设计模式抽象工厂模式抽象工厂模式 今天我们一起来探究抽象工厂模式&#x…

tensorflow.js 使用场景

TensorFlow.js (简称 TF.js) 是一个利用 WebGL 和 Node.js 在浏览器和服务器端进行机器学习模型训练和部署(推理)的 JavaScript 库。它的核心价值在于将机器学习的能力带入了 Web 开发者和 JavaScript 生态的领域。 其主要应用场景可以分为以下几大类: 一、在浏览器中直接进…