龙空技术网

Python序列-元组(tuple)

死胖子没有未来啊 157

前言:

今天同学们对“python取元组中的元素”都比较重视,看官们都需要了解一些“python取元组中的元素”的相关资讯。那么小编在网上汇集了一些关于“python取元组中的元素””的相关文章,希望各位老铁们能喜欢,看官们快快来学习一下吧!

Python 的元组与列表类似,不同之处在于元组的元素不能修改。

元组与列表的区别,元组它的关键是不可变性。

如果在程序中以列表的形式传递一个对象的集合,它可能在任何地方改变;

如果使用元组的话,则不能。

元组提供了一种完整的约束。

元组使用小括号,列表使用方括号。

元组创建很简单,只需要在括号中添加元素,并使用逗号隔开即可。

实例(Python 3.0+)

>>> tup1 = ('Google', 'Runoob', 1997, 2000)

>>> tup2 = (1, 2, 3, 4, 5 )

>>> tup3 = "a", "b", "c", "d" # 不需要括号也可以

>>> type(tup3) <class 'tuple'>

创建空元组

tup1 = ()

一、创建元组

代码如下:

tup1 = ('physics', 'chemistry', 1997, 2000);

tup2 = (1, 2, 3, 4, 5 );

tup3 = "a", "b", "c", "d";

创建空元组

代码如下:

tup1 = ();

元组中只包含一个元素时,需要在元素后面添加逗号来消除歧义

代码如下:

tup1 = (50,);

元组与字符串类似,下标索引从0开始,可以进行截取,组合等。

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

实例(Python 3.0+)

>>>tup1 = (50)

>>> type(tup1) # 不加逗号,类型为整型 <class 'int'>

>>> tup1 = (50,)

>>> type(tup1) # 加上逗号,类型为元组 <class 'tuple'>

访问元组元组可以使用下标索引来访问元组中的值,如下实例:

tup1 = ('Google', 'Runoob', 1997, 2000)

tup2 = (1, 2, 3, 4, 5, 6, 7 )

print ("tup1[0]: ", tup1[0])

print ("tup2[1:5]: ", tup2[1:5])

以上实例输出结果:

tup1[0]: Google

tup2[1:5]: (2, 3, 4, 5)

代码如下:

tup1 = ('physics', 'chemistry', 1997, 2000);

tup2 = (1, 2, 3, 4, 5, 6, 7 );

print "tup1[0]: ", tup1[0]

print "tup2[1:5]: ", tup2[1:5]

#以上实例输出结果:

#tup1[0]: physics

#tup2[1:5]: [2, 3, 4, 5]

元组索引,截取

因为元组也是一个序列,所以我们可以访问元组中的指定位置的元素,也可以截取索引中的一段元素,如下所示:

元组:

L = ('Google', 'Taobao', 'Runoob')

L[2]

'Runoob'

读取第三个元素

L[-2]

'Taobao'

反向读取,读取倒数第二个元素

L[1:]

('Taobao', 'Runoob')

截取元素,从第二个开始后的所有元素。

同列表一样,元组也可以用for循环进行遍历。

例:

coffeename = ('蓝山','卡布奇诺','曼特宁','摩卡','麝香猫','哥伦比亚') # 定义元组

print("您好,欢迎光临 ~ 伊米咖啡馆 ~\n\n我店有:\n")

for name in coffeename: #遍历元组

print(name + "咖啡",end = " ")

输出:

您好,欢迎光临 ~ 伊米咖啡馆 ~

我店有:

蓝山咖啡 卡布奇诺咖啡 曼特宁咖啡 摩卡咖啡 麝香猫咖啡 哥伦比亚咖啡

使用for循环和使用enumerate()函数结合进行遍历。

enumerate()函数用于将一个可遍历的数据对象(或列表或元组)组合成一个索引序列,同时列出数据和数据下标,一般在for循环中使用。

例:

print("2017~2018赛季NBA西部联盟前八名\n")

team = ("火箭","勇士","开拓者","雷霆","爵士","鹈鹕","马刺","森林狼")

for index,item in enumerate(team):

if index%2 == 0: # 判断是否为偶数,为偶数时不换行

print(item +"\t\t", end='')

else:

print(item + "\n") # 换行输出

输出:

2017~2018赛季NBA西部联盟前八名

火箭 勇士

开拓者 雷霆

爵士 鹈鹕

马刺 森林狼

扩展:‘ ,end=’ ’ ’表示不换行输出,即下一条print()的输出内容会和这个内容在同一行输出。

修改元组元组是不可变序列,所以不能对它的单个元素值进行修改。但是可以通过对元组进行重新赋值。

例:

coffeename = ('蓝山','卡布奇诺','曼特宁','摩卡','麝香猫','哥伦比亚') # 定义元组

coffeename = ('蓝山','卡布奇诺','曼特宁','摩卡','拿铁','哥伦比亚') # 对元组进行重新赋值

print('新元组:',coffeename)

输出:

新元组: ('蓝山', '卡布奇诺', '曼特宁', '摩卡', '拿铁', '哥伦比亚')

还可以对元组进行连接组合,如下实例:

代码如下:

coffeename = ('蓝山','卡布奇诺','曼特宁','摩卡')

print('原元组:',coffeename)

coffeename = coffeename + ('拿铁', '哥伦比亚')

print('组合后:',coffeename)

输出:

原元组: ('蓝山', '卡布奇诺', '曼特宁', '摩卡')

组合后: ('蓝山', '卡布奇诺', '曼特宁', '摩卡', '拿铁', '哥伦比亚')

注意:在进行元组连接时,连接的内容都必须是元组。不能将元组和字符串或者列表进行连接。

在进行元组连接时,如果要连接的元组只有一个元素时,一定不要忘记后面的逗号。

coffeename = ('蓝山','卡布奇诺','曼特宁','摩卡')

print('原元组:',coffeename)

coffeename = coffeename + ('拿铁',) # 元组只有一个元素时,一定不要忘记后面的逗号

print('组合后:',coffeename)

输出:

原元组: ('蓝山', '卡布奇诺', '曼特宁', '摩卡')

组合后: ('蓝山', '卡布奇诺', '曼特宁', '摩卡', '拿铁')

删除元组

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

如下实例:

tup = ('Google', 'Runoob', 1997, 2000)

print (tup)

del tup

print ("删除后的元组 tup : ")

print (tup)

以上实例元组被删除后,输出变量会有异常信息,输出如下所示:

('Google', 'Runoob', 1997, 2000)

删除后的元组 tup :

Traceback (most recent call last):

File "d:/py/空白试验.py", line 5, in <module>

print (tup)

NameError: name 'tup' is not defined

元组运算符

与字符串一样,元组之间可以使用 + 号和 * 号进行运算。这就意味着他们可以组合和复制,运算后会生成一个新的元组。

元组内置函数

Python元组包含了以下内置函数

序号

方法及描述

实例

1

len(tuple)

计算元组元素个数。

参数

· tuple -- 要计算的元组。

返回值

函数返回元组元素个数

tuple1, tuple2 = (123, 'xyz', 'zara'), (456, 'abc')

print "First tuple length : ", len(tuple1);

print "Second tuple length : ", len(tuple2);

以上实例输出结果如下:

First tuple length : 3

Second tuple length : 2

2

max(tuple)

返回元组中元素最大值。

>>> tuple2 = ('5', '4', '8')

>>> max(tuple2)

'8'

>>>

3

min(tuple)

返回元组中元素最小值。

>>> tuple2 = ('5', '4', '8')

>>> min(tuple2)

'4'

>>>

4

tuple(iterable)

将可迭代系列转换为元组。

>>> list1= ['Google', 'Taobao', 'Runoob', 'Baidu']

>>> tuple1=tuple(list1)

>>> tuple1('Google', 'Taobao', 'Runoob', 'Baidu')

5

cmp(tuple1, tuple2):

比较两个元组元素。

如果比较的元素是同类型的,则比较其值,返回结果。

如果两个元素不是同一种类型,则检查它们是否是数字。

如果是数字,执行必要的数字强制类型转换,然后比较。

如果有一方的元素是数字,则另一方的元素"大"(数字是"最小的")

否则,通过类型名字的字母顺序进行比较。

如果有一个列表首先到达末尾,则另一个长一点的列表"大"。

如果我们用尽了两个列表的元素而且所 有元素都是相等的,那么结果就是个平局,就是说返回一个 0。

tuple1, tuple2 = (123, 'xyz'), (456, 'abc')

print cmp(tuple1, tuple2);

print cmp(tuple2, tuple1);

tuple3 = tuple2 + (786,);

print cmp(tuple2, tuple3)

tuple4 = (123, 'xyz')

print cmp(tuple1, tuple4)

以上实例输出结果如下:

-1

1

-1

关于元组是不可变的

所谓元组的不可变指的是元组所指向的内存中的内容不可变。

>>> tup = ('r', 'u', 'n', 'o', 'o', 'b')

>>> tup[0] = 'g' # 不支持修改元素

Traceback (most recent call last):

File "<stdin>", line 1, in <module>

TypeError: 'tuple' object does not support item assignment

>>> id(tup) # 查看内存地址

4440687904

>>> tup = (1,2,3)

>>> id(tup)

4441088800 # 内存地址不一样了

从以上实例可以看出,重新赋值的元组 tup,绑定到新的对象了,不是修改了原来的对象。

七、无关闭分隔符

任意无符号的对象,以逗号隔开,默认为元组。

八、另一种解读

tuple和list非常类似,但是tuple一旦初始化就不能修改,比如同样是列出同学的名字:

代码如下:

>>> classmates = ('Michael', 'Bob', 'Tracy')

现在,classmates这个tuple不能变了,它也没有append(),insert()这样的方法。其他获取元素的方法和list是一样的,你可以正常地使用classmates[0],classmates[-1],但不能赋值成另外的元素。

不可变的tuple有什么意义?因为tuple不可变,所以代码更安全。如果可能,能用tuple代替list就尽量用tuple。

tuple的陷阱:当你定义一个tuple时,在定义的时候,tuple的元素就必须被确定下来,比如:

代码如下:

>>> t = (1, 2)

>>> t

(1, 2)

如果要定义一个空的tuple,可以写成():

代码如下:

>>> t = ()

>>> t

()

但是,要定义一个只有1个元素的tuple,如果你这么定义:

代码如下:

>>> t = (1)

>>> t

1

定义的不是tuple,是1这个数!这是因为括号()既可以表示tuple,又可以表示数学公式中的小括号,这就产生了歧义,因此,Python规定,这种情况下,按小括号进行计算,计算结果自然是1。

所以,只有1个元素的tuple定义时必须加一个逗号,,来消除歧义:

代码如下:

>>> t = (1,)

>>> t

(1,)

Python在显示只有1个元素的tuple时,也会加一个逗号,,以免你误解成数学计算意义上的括号。

在来看一个“可变的”tuple:

代码如下:

>>> t = ('a', 'b', ['A', 'B'])

>>> t[2][0] = 'X'

>>> t[2][1] = 'Y'

>>> t

('a', 'b', ['X', 'Y'])

这个tuple定义的时候有3个元素,分别是'a','b'和一个list。不是说tuple一旦定义后就不可变了吗?怎么后来又变了?

别急,我们先看看定义的时候tuple包含的3个元素:

当我们把list的元素'A'和'B'修改为'X'和'Y'后,tuple变为:

表面上看,tuple的元素确实变了,但其实变的不是tuple的元素,而是list的元素。tuple一开始指向的list并没有改成别的list,所以,tuple所谓的“不变”是说,tuple的每个元素,指向永远不变。即指向'a',就不能改成指向'b',指向一个list,就不能改成指向其他对象,但指向的这个list本身是可变的!

理解了“指向不变”后,要创建一个内容也不变的tuple怎么做?那就必须保证tuple的每一个元素本身也不能变。

元组的一级元素不可被修改增加删除但可以修改二级后的。

如修改元祖中列表,字典等内容:

>>> tu = ("alex", [11, 22, {"k1": 'v1', "k2": ["age", "name"], "k3": (11,22,33)}, 44])>>> tu[1][2]["k2"].append("seven")>>> print(tu[1][2]["k2"])['age', 'name', 'seven']>>>

添加元祖中的字典中的列表。

元组推导式:

使用元组推导式可以快速生成一个元组,它的表现形式与列表推导式类似,只是将列表推导式中的‘[]’修改为‘()’.

例:要求生成一个包括10个随机数的列表,要求范围在10-100(包括)之间

>>>import random #导入random模块

>>>randomnumber = (random.randint(10,100) for i in range(10))

#randint用来生成随机数,在使用randint之前,需要调用random库。

#其表达是为random.randint(x,y).参数x和y代表生成随机数的区间范围

>>>print(‘生成的随机数元组为:’,randomnumber)

输出:

生成的随机数元组为: <generator object <genexpr> at 0x000002757F739748>

这就是与列表推导式的差别,直接生成的结果并不是一个元组或者列表,而是一个生成器对象。

要使该生成器对象可以转换为元组或者列表:

转换为元组使用:tuple()函数。

转换为列表使用:list()函数。

同样时生成随机数,可以使用以下代码

例:

import random #导入random模块

randomnumber = (random.randint(10,100) for i in range(10))

#randint用来生成随机数,在使用randint之前,需要调用random库。

#其表达是为random.randint(x,y).参数x和y代表生成随机数的区间范围

randomnumber = tuple(randomnumber)

print("生成的随机数元组为:",randomnumber)

randomnumber = list(randomnumber)

print("生成的随机数列表为:",randomnumber)

输出

生成的随机数元组为: (72, 86, 90, 95, 86, 54, 77, 83, 99, 86)

生成的随机数列表为: [72, 86, 90, 95, 86, 54, 77, 83, 99, 86]

标签: #python取元组中的元素