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

熟练掌握Python元组不得不知道的10件应知事项

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

全文共3618字,预计学习时长11分钟



人生苦短,Python是岸。


作为一种通用编程语言,Python已成为各学术和工业领域中最流行的语言之一。


此前,IEEESpectrum 发布的第五届年度编程语言交互排行榜中,Python 不但雄踞第一,在综合指数、用户增速、就业优势和开源语言单项中,全部霸占榜首。


Python拥有强大的数据结构集合,例如int、 string、 list、 dict和 tuple——一个大小固定且不可变数据序列。


在今天的文章里,小芯将带领大家回顾正确使用Python元组的最常用方法。


1.使用索引访问元组中的单个元素


创建元组后,有时需要访问它的一些值。一种方法是使用基于0的索引对其进行访问。参见下方示例。值得注意的是,在Python中,使用负数以相反的顺序索引序列。例如,-1是序列中最后一个元素的索引。当然,如试图使用范围之外的索引访问元素,将看到IndexError(索引错误)。


>>> tuple_index = (100,'text', False, {1: 'five', 2: True})>>> tuple_index[0]
100>>> tuple_index[-1]
{1: 'five', 2: True}>>> tuple_index[2]
False>>> tuple_index[6]
Traceback (most recent call last):
  File "<stdin>", line 1,in <module>
IndexError: tuple index out of range


2.可变元素


虽然一个元组不能作为一个对象整体改变,但如果单个元素本身是可变的,就可以对其进行更改。参见下方示例。具体来说,修改了tuple(元组)中的 list 和 dict.


>>> mutable_elements =(1, [1, 2], {0: 'zero', 1: 'one'})>>> mutable_elements[1].append(3)
>>> mutable_elements
(1, [1, 2, 3], {0: 'zero', 1: 'one'})>>> mutable_elements[2][2] ='two'
>>> mutable_elements
(1, [1, 2, 3], {0: 'zero', 1: 'one', 2: 'two'})


3.高级元组拆包


有时拆包一个元组,并不需要访问所有的单个元素。对于那些不重要的元素,可以用下划线(_)表示。另一种高级的tuple (元组)拆包技术是,使用星号(*)表示tuple (元组)中的元素序列。_和*用法也可以组合使用。

>>> advanced_unpacking0= (1, 2, 3)
>>> a, _, c = advanced_unpacking0
>>> a
1
>>> c
3>>> advanced_unpacking1 = (1, 2, 3, 4, 5, 11, 12, 13, 14, 15)
>>> a, *middle, c = advanced_unpacking1
>>> middle
[2, 3, 4, 5, 11, 12, 13, 14]
>>> _, *tail = advanced_unpacking1
>>> tail
[2, 3, 4, 5, 11, 12, 13, 14, 15]
>>> head, *_ = advanced_unpacking1
>>> head
1


4.使用值序列创建元组



创建元组时,需使用逗号分隔值序列。括号是可选的,尤其在声明表达式不直接的情况下,使用括号可以提高可读性。


>>> tuple0 = 1, 4, 5
>>> print(tuple0)
(1, 4, 5)>>> tuple1 = (1, 2, 'three')
>>> print(tuple1)
(1, 2, 'three')>>> tuple2 = (4, 7, ('a', 'b'), lambda x: x+1)
>>> print(tuple2)
(4, 7, ('a', 'b'), <function <lambda> at 0x106e98830>)>>>tuple3 = ()
>>> print(tuple3)
()>>> tuple4 = 'one',
>>> print(tuple4)
('one',)


特殊的情况是:使用一对括号创建一个空tuple(元组);在唯一值后使用逗号创建单值tuple(元组)。


5.计算元组中元素的数量


由于tuple(元组)是一个序列,所以可使用len()函数计算所有元素总数。另一个函数 count()也很方便,可用做计算调用时指定的某个值的个数。参见下方示例。

>>> tuple_len = (1, 3,'one', 'three', 'five')
>>> len(tuple_len)
5>>> tuple_count = (1, 1, 2, 2, 2, 2, 3, 3, 3)
>>> tuple_count.count(2)
4
>>> tuple_count.count(3)
3


6.使用tuple()函数创建元组


可使用内置 tuple()方法创建元组,该方法将 iterable (迭代)作为唯一参数。生成的tuple (元组)将是 iterable 的迭代项序列。如下示例中,元组分别从str、dict和 list生成。


>>> tuple5 =tuple(['a', 'b'])
>>> print(tuple5)
('a', 'b')>>> tuple6 = tuple('tuple')
>>> print(tuple6)
('t', 'u', 'p', 'l', 'e')>>> tuple7 = tuple({'a': 1, True: 4})
>>> print(tuple7)
('a', True)>>> tuple8 = tuple((1, 'two', [1, 2]))
>>> print(tuple8)
(1, 'two', [1, 2])


7.使用拆包方法访问元组的单个元素


使用元组可能经常听到的另一个概念是tuple(元组)拆包,它允许访问单个元素。参见下方示例。

>>> tuple_unpacking =(1, 'two', [3, 3, 3], {'four': 4})
>>> a, b, c, d = tuple_unpacking>>> a
1
>>> b
'two'
>>> c
[3, 3, 3]
>>> d
{'four': 4}


8.for循环中的元组



时常需要在for循环中使用元组。由于元组是可迭代的,所以可直接在for循环中使用,该循环将迭代元组的单个元素。或者,如果想应用计数器,可使用元组内置的 enumerate() 方法。参见下方示例。


>>> tuple_for_loop =('one', 'two', 'three')
>>> for i in tuple_for_loop:
... print(i)
...
one
two
three>>> for (i, item) in enumerate(tuple_for_loop, start=1):
... print(str(i) + ': is ' + item)
...
1: is one
2: is two
3: is three


9.元组的不可变性


正如本文开头提到的,元组是一个不可变值序列。因此,不能改变单个元素的值。


>>> immut_tuple = (3,5, 7)
>>> immut_tuple[0] = 1
Traceback (most recent call last):
File "<stdin>", line 1,in <module>
TypeError: 'tuple' object does not support item assignment


10.元组连接


可使用加号(+)运算符连接多个元组,来创建一个新元组。或者,如果想通过多次连接同一元组来创建一个新的元组,可使用乘法(*)运算符。


>>> concat_tuple0 = (1,2) + ('three', 4) + ('five', 6)
>>> concat_tuple0
(1, 2, 'three', 4, 'five', 6)>>> concat_tuple1 = ('odd', 'event') * 4
>>> concat_tuple1
('odd', 'event', 'odd', 'event', 'odd', 'event', 'odd', 'event')



元组是笔者在Python编程中最喜欢使用的数据结构之一,因其便于构造和访问单个元素。当然,请记住元组是不可变的,并且没有过多的方法,这可能限制其更广泛的使用,这种情况下,可以考虑使用list 或dict.


留言点赞关注

我们一起分享AI学习与发展的干货

如转载,请后台留言,遵守转载规范

相关推荐

第 28 章:核心功能 SQL 查询 - PostgreSQL入门

欢迎来到我们史诗级教程的最终章!在上一章,我们成功地构建了博客系统的数据库骨架。现在,这个结构精良的数据库正静静地等待着我们去使用它。...

postgresql的6种索引介绍_postgresql默认用户名和密码

postgresql几种索引PostgreSQL支持多种索引类型,每种索引的设计原理、适用场景和优缺点各有不同。以下是对主要索引类型的详细介绍:...

第 20 章:索引与性能优化 - PostgreSQL入门

到目前为止,我们已经学习了如何设计表、保证数据完整性、以及如何用各种方式查询数据。但当我们的表从几十行增长到几百万、甚至上亿行时,一个之前只需要0.1秒的查询,可能会变成需要几分钟甚至几小时的“灾...

PostgreSQL 主从复制 完整指南_主从复制mysql

PostgreSQL主从复制(StreamingReplication)完整指南PostgreSQL主从复制是一种实时同步数据的机制,可以实现高可用性(HA)、读写分离和负载均衡。其...

PostgreSQL监控神器,千万注意这5大关键指标!

PostgreSQL监控神器,千万注意这5大关键指标!在当今数据驱动的业务环境中,数据库的性能和稳定性直接关系到企业的运营效率与用户体验。PostgreSQL作为一款功能强大的开源关系型数据库,被广泛...

Retool 如何升级主应用 4TB 的 PostgreSQL 数据库

本文最初发布于Retool官方博客。...

PostgreSQL查询计划_postgresql查询计划中的cost组成

深入解析PostgreSQL查询计划:优化性能的关键在数据库管理系统中,查询计划是执行SQL查询时的关键组成部分。PostgreSQL作为一款功能强大的开源关系型数据库,其查询计划的生成与优化对于提升...

第 27 章:数据库与表结构实现 - PostgreSQL入门

在上一章,我们已经绘制好了博客系统的宏伟蓝图。现在,是时候戴上安全帽,化身“建筑工程师”,将图纸上的设计一砖一瓦地搭建成真实的数据库结构了。...

谁帮我看看,为啥我的PostgreSQL查询速度这么慢???

...

PostgreSQL事务处理_postgresql时区问题

PostgreSQL事务处理:原理、应用与优化引言...

第 14 章:集合运算 (UNION, INTERSECT, EXCEPT) - PostgreSQL入门

在之前的章节里,我们所有的操作(JOIN...

PostgreSQL 安装指南及日常使用_postgresql 11安装

PostgreSQL安装与日常使用PostgreSQL是一款功能强大、开源的对象关系型数据库,支持高级SQL标准、扩展功能、事务完整性和高并发。本指南涵盖安装、配置、日常使用、性能优化、常见...

第 23 章:函数与存储过程 (PL/pgSQL) - PostgreSQL入门

到目前为止,我们与数据库的交互方式都是从外部客户端(如psql...

PostgreSQL是不是你的下一个JSON数据库?

根据Betteridge定律(任何头条的设问句可以用一个词来回答:不是),除非你的JSON数据很少修改,并且查询很多。最新版的PostgreSQL添加更多对JSON的支持,我们曾经问过PostgreS...

&quot;揭秘PostgreSQL:你必须掌握的数据类型全解析!&quot;

揭秘PostgreSQL:你必须掌握的数据类型全解析!在数据库管理系统中,PostgreSQL以其强大的功能和稳定性而著称。为了充分发挥其性能,理解并熟练掌握其数据类型是至关重要的。本文将深入探讨Po...