百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

Python学习(八)元组的创建及常用操作详解

wptr33 2024-11-18 17:46 33 浏览

什么是元组?

Python内置的数据结构之一,是一个不可变序列
不可变序列与可变序列的区别:
			不可变序列:字符串、元组【没有增、删、改、查的操作】
      可变序列:列表、字典【可以对序列执行增、删、改、查操作;且对象地址不发生更改】
      
# 可变序列  列表、字典
lst = [10,20,30]
print('新增前列表地址',id(lst)) # 新增前列表地址 2997720003584
lst.append(300)
print('新增后列表地址',id(lst)) # 新增后列表地址 2997720003584

# 不可变序列  字符串、元组
s = 'python'
print('新增前字符串地址',s,id(s)) # 新增前字符串地址 python 2997720003248
s = 'hello '+s
print('新增后字符串地址',s,id(s)) # 新增后字符串地址 hello python 2997720311088

元组的创建方式

直接使用小括号 (): a = ('Python','hello',12)  或者 	a = 'Python','hello',12

使用内置函数 tuple():  a = tuple( ('Python','hello',12))

只包含一个元组的元素需要使用逗号和小括号:	a =  ('Python',)

创建空元组:a = () 	或者	a = tuple()

为什么要将元组设计为不可变序列

在多线程环境下,同时操作对象时不需要加锁。因此在程序中尽量使用不可变序列。

注意:元组中存储的时对象的引用。
		1)如果元组中对象本身不可对象,则不能再引用其它对象
    2)如果元组中的对象是可变对象,则可变对象的引用不允许改变,但数据可以改变。
t = (10,['python',12],9)
print('操作前的元组',t,type(t)) # 操作前的元组 (10, ['python', 12], 9) 	<class 'tuple'>
print('取下标为0的元素',t[0],type(t[0]),id(t[0])) # 取下标为0的元素 10                  <class 'int'>  2057875712592

print('取下标为1的元素',t[1],type(t[1]),id(t[1])) # 取下标为1的元素 ['python', 12] <class 'list'> 2057876746752
# 由于  ['python', 12] 是一个列表,是可变序列。所以可以向列表中添加元素,但是列表的内存地址不会发生改变
t[1].append(100) # 向列表中添加元素
print('添加元素后的列表',t[1],id(t[1])) # 添加元素后的列表              ['python', 12, 100]              2057876746752

print('取下标为2的元素',t[2],type(t[2]),id(t[2])) # 取下标为2的元素 9                    <class 'int'>  2057875712560

元组的遍历

元组是可迭代对象,所以可以使用 for... ...in 进行遍历
t = (10,['python',12],9)
# 使用索引获取元组元素
print('使用索引获取的元组元素',t[0])
# print('使用索引获取的元组元素',t[3]) # IndexError: tuple index out of range 索引下标在元组中不存在时,会返回索引超出范围的异常
# 遍历元组
for item in t:
    print('使用for...in遍历获取的元组元素',item)

相关推荐

HIVE 窗口函数详解(hive常用开窗函数)

什么是窗口函数窗口函数是SQL中一类特别的函数。和聚合函数相似,窗口函数的输入也是多行记录。不同的是,聚合函数的作用于由GROUPBY子句聚合的组,而窗口函数则作用于一个窗口,这里,窗口...

SQL高效使用20招:数据分析师必备技巧

基础优化技巧善用EXPLAIN分析执行计划EXPLAINSELECT*FROMordersWHEREorder_date>'2024-01-01';...

答记者问之 - Redis 的高效架构与应用模式解析

问:极客程序员你好,请帮我讲一讲redis答:redis主要涉及以下核心,我来一一揭幕Redis的高效架构与应用模式解析...

MySQL通过累计求新增(mysql新增表字段语句)

前两天的那篇内容《MySQL递归实现单列分列成多行》...

一文讲懂SQL窗口函数 大厂必考知识点

大家好,我是宁一。今天是我们的第24课:窗口函数。...

圣诞快乐:用GaussDB T 绘制一颗圣诞树,兼论高斯数据库语法兼容

转眼就是圣诞的节日,祝大家节日快乐。用GaussDBT(也就是GaussDB100)绘制一棵圣诞树,纯国产,更喜庆。话不多说,上图:SQL如下:SELECTCASEWHENENMOTE...

Minitab:功能强大的质量管理、统计分析及统计图形软件

一、Minitab简介Minitab软件是为质量改善、教育和研究应用领域提供统计软件和服务的先导,是全球领先的质量管理和六西格玛实施软件工具及持续质量改进的良好工具软件,她具有强大的功能和简易的可视化...

如何熟练使用SQL查询(如何熟练使用sql查询内容)

要熟练使用SQL查询(StructuredQueryLanguage),你需要系统地从语法入门,到实战练习,再到性能优化与多表查询的掌握。下面是一条循序渐进、实战驱动的学习路径:第一阶段:S...

SAP SE38如何在多个系统间同步代码

上一篇文章写了如何在多个系统之间同步开发对象:多套SAPERP之间一键同步ABAP开发内容,有兄弟问有没有简单办法同步SE38程序代码的,因为使用请求的方式同步代码有点小题大做了。...

Python | 垂直模态分解(phython垂直输出)

...

技术栈:刷了百道SQL题,还是不会用?你应该这样补短板

这是来自用户的提问,也是很多人遇到的困惑:...

mysql窗口函数为了解决更加复杂的问题

为了解决复杂问题的窗口函数我们先讲一下窗口函数是什么窗口和普通的函数作用相同在不同列上进行查询和返回比如我们有如下的表...

MariaDB开窗函数(开窗函数 mysql)

在使用GROUPBY子句时,总是需要将筛选的所有数据进行分组操作,它的分组作用域是整张表。分组以后,为每个组只返回一行。而使用基于窗口的操作,类似于分组,但却可以对这些"组"(即窗口...

一文掌握 DuckDB 时间序列分析:窗口函数实战详解

...

一篇文章搞定MySQL中的窗口函数(mysql常用的窗口函数)

我是孙斌,北理数学系毕业,分享数据分析相关知识,点击右上角“关注”,学习更多数据分析知识。在MySQL中,分组groupby一般和聚合函数连用,如groupby+sum,这样能够得到每个组的总和,...