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

Python笔记-什么是元组?

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

什么是元组?

元组是一个固定长度, 不可改变的Python序列对象。 创建元组的最简单方式, 是用

逗号分隔一列值:

>>> tup = 4, 5, 6
>>> tup
(4, 5, 6)

当用复杂的表达式定义元组, 最好将值放到圆括号内, 如下所示:

>>> b=(4, 5, 6), (7, 8)

>>> b

((4, 5, 6), (7, 8))

元组的一些操作

1.元组的替换、拆分

用 tuple 可以将任意序列或迭代器转换成元组:

(1)字符串能自动拆分成各个字母

>>> c=tuple('string') #tuple方法

>>> c

('s', 't', 'r', 'i', 'n', 'g')

(2)拆分序列

>>> tuple([1,2,3])

(1, 2, 3)

(3)元组中存储的对象可能是可变对象。 一旦创建了元组, 元组中的对象就不能修改

了;但,如果元组中的某个对象是可变的, 比如列表, 可以在原位进行修改:

>>> d=tuple(['foo', [1, 2], True])

>>> d

('foo', [1, 2], True)

>>> d[0]

'foo'

>>> d[1]

[1, 2]

>>> d[2]

True
>>> d[1].append(10) #list可修改,在原位修改list

>>> d

('foo', [1, 2, 10], True)

>>> d[2]=False #元组不可修改,修改元组会出错

Traceback (most recent call last):

File "<pyshell#122>", line 1, in <module>

d[2]=False

TypeError: 'tuple' object does not support item assignment

2.元组的"+"、"*"运算

可以用加号运算符(+)将元组串联起来:

>>> (4, None, 'foo') + (6, 0) + ('bar',)

(4, None, 'foo', 6, 0, 'bar')

可以用乘号运算符(*)将元组复制串联:

>>> ('foo', 'bar') * 4

('foo', 'bar', 'foo', 'bar', 'foo', 'bar', 'foo', 'bar')

>>> (1,2,3)*3

(1, 2, 3, 1, 2, 3, 1, 2, 3)

3.拆分元组

元组数据不可修改,但是元组可以方便的赋值给其他变量,数量相同时,可以一次赋值给多个变量。

>>> a=4,5,6 #创建一个元组

>>> a #创建的元组的值

(4, 5, 6)

>>> a,b,c=a #元组赋值给新变量a,b,c

>>> a

4

>>> b

5

>>> c

6

元组中嵌套的元组也会被拆分赋值

>>> a,b,c=1,2,(0,8)

>>> c

(0, 8)

>>> d,e,(f,g)=1,2,(0,8)

>>> f

0

直接交换两个变量

>>> a,b=1,2

>>> a

1

>>> b

2

>>> a,b=b,a

>>> a

2

>>> b

1

变量拆分常用来迭代元组或列表序列:

>>> seq=[(1,2,3),(4,5,6),(7,8,9)]

>>> for a,b,c in seq:

print('a={0},b={1},c={2}'.format(a,b,c))

a=1,b=2,c=3

a=4,b=5,c=6

a=7,b=8,c=9

Python最近新增了更多高级的元组拆分功能, 允许从元组的开头"摘取"几个元素。

它使用了特殊的语法 *rest , 这也用在函数签名中以抓取任意长度列表的位置参

数:

>>> values=1,2,3,4,5,6,7

>>> a,b,*rest=values #程序员 a,b,*_=values

>>> a

1

>>> b

2

>>> rest

[3, 4, 5, 6, 7]

rest 的部分是想要舍弃的部分, rest的名字不重要。 作为惯用写法, 许多Python

程序员会将不需要的变量使用下划线:

4.tuple方法

因为元组的大小和内容不能修改, 它的实例方法都很轻量。 其中一个很有用的就

是 count ( 也适用于列表) , 它可以统计某个值得出现频率:

>>> tup=a,a,a,b,b,c

>>> tup.count(a)

3

相关推荐

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,这样能够得到每个组的总和,...