[笛卡尔积]中每一个素(d1,d2,…,dn),叫作一个n元组(n-tuple)或简称元组。当关系是一张表,二维表中的行表中的每行(即中的每条记录)就是一个元组,每列就是一个属性。在二维表里,元组也称为记录。
元组是一系列不可变的Python对象。元组是一种序列,就像列表一样。元组和列表之间的主要区别是元组不能像列表那样改变元素的值,可以简单地理解为“只读列表”。 元组使用小括号 - ()
,而列表使用方括号 - []
。
元组的定义语法
变量名 = (数据1, 数据2, 数据3,...)
eg:
uesr_tuple = ("zhangsan", "lisi", "wangwu")
元组中各元素之间用逗号隔开。元组不支持修改或删除其所包含的元素。如果要修改,则可以使用list函数把它转化成列表,然后在列表上进行修改创建元组的方法有三种:
1、使用括弧“0”来创建,例如,a=(1,2,3);
2、使用逗号来创建,例如,b=2,4;
3、使用 tuple0函数把其他种类的序列转化为元组,例如,c= tuple(“Good!”)。 [3]
创建一个元组只需使用逗号分隔值放入小括号的一个序列。 或者,也可以将这些逗号分隔值放在括号之间。 例如 -
tup1 = ('physics', 'chemistry', 1997, 2000)
tup2 = (1, 2, 3, 4, 5 )
tup3 = "a", "b", "c", "d"
Python
空的元组写成两个不含任何东西的小括号 -
tup1 = ();
Python
要编写一个包含单个值的元组,必须包含一个逗号,即使只有一个值(这是规范写法) -
tup1 = (50,)
## 也可以这样写
tup2 = (50)
Python
要访问元组中的值,请使用方括号进行指定索引切片或索引,以获取该索引处的值。 例如 -
#!/usr/bin/python3
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])
Shell
当执行上述代码时,会产生以下结果 -
tup1[0]: physics
tup2[1:5]: (2, 3, 4, 5)
Python
# 定义空元组;
empty_tuple = ()
type(empty_tuple) # tuple
# 定义一个单元素元组;
# 如果元组中只有一个数据,要在那一个数据后面加逗号,否则该元组变量会被python解释器认为是括号内数据的数据类型;
single_tuple = (5)
type(single_tuple) # int
single_tuple = (5,)
type(single_tuple) # tuple
元组是不可变的,这意味着我们无法更新或更改元组元素的值。 但是可以使用现有元组的一部分来创建新的元组,如下例所示:
#!/usr/bin/python3
tup1 = (12, 34.56)
tup2 = ('abc', 'xyz')
# Following action is not valid for tuples
# tup1[0] = 100;
# So let's create a new tuple as follows
tup3 = tup1 + tup2
print (tup3)
Python
当执行上述代码时,会产生以下结果 -
(12, 34.56, 'abc', 'xyz')
Shell
删除单个元组元素是不可能的。 当然,将不必要的元素放在另一个元组中也没有什么错。
要显式删除整个元组,只需使用del
语句。 例如 -
#!/usr/bin/python3
tup = ('physics', 'chemistry', 1997, 2000);
print (tup)
del tup;
print "After deleting tup : "
print (tup)
Python
执行上面代码,将产生以下结果 -
注 - 引发异常。这是因为在
del tup
之后,元组不再存在。
('physics', 'chemistry', 1997, 2000)
After deleting tup :
Traceback (most recent call last):
File "test.py", line 9, in <module>
print tup;
NameError: name 'tup' is not defined
Shell
元组响应+
和*
运算符很像字符串; 它们执行连接和重复操作,但结果是一个新的元组,而不是一个字符串。
事实上,元组中类似字符串操作和使用的所有常规序列操作都有作了讲解。
Python表达式 | 结果 | 描述 |
---|---|---|
len((1, 2, 3)) |
3 |
长度 |
(1, 2, 3) + (4, 5, 6) |
(1, 2, 3, 4, 5, 6) |
连接操作 |
('Hi!',) * 4 |
('Hi!', 'Hi!', 'Hi!', 'Hi!') |
重复 |
3 in (1, 2, 3) |
True |
成员关系 |
for x in (1,2,3) : print (x, end = ' ') |
1 2 3 |
迭代 |
由于元组是序列,索引和切片的工作方式与列表的工作方式相同,假设输入以下值:
T=('C++', 'Java', 'Python')
Python
那么 -
Python表达式 | 结果 | |
---|---|---|
T[2] |
'Python' |
偏移量,从零开始 |
T[-2] |
'Java' |
负数:从右到左 |
T[1:] |
('Java', 'Python') |
切片提取部分 |
元组遍历就是 从头到尾 依次从元组中取数据;
每次循环都将 从元组中顺序的读取出来的数据放在临时变量中,然后执行相同的操作。
使用for进行迭代遍历。
user_tuple = ["zhangsan", 20, 181]
for i in user_tuple:
# 因为通常元组的元素数据类型不同,所以一般很少遍历元组做操作,
# 除非确定元组中每一个元素的数据类型
print(i)
在Python中,可以使用for循环遍历所有非数字型类型的变量:列表,元组,字典以及字符串;
格式化后面的括号和内容,本质上就是元组;我们可以先定义一个元组,然后在格式化后面%元组,一样能输出;
同时,我们甚至可以将print括号里面的函数拿出来,定义成一个变量,再用print输出。
# 四者的输出结果都一样
# zhangsan 的年龄是 20, 身高是 181
name = "zhangsan"
age = 20
height = 181
print("%s 的年龄是 %d, 身高是 %d" % (name, age, height))
userinfo = ("zhangsan", 20, 181)
print("%s 的年龄是 %d, 身高是 %d" % (userinfo[0], userinfo[1], userinfo[2]))
# 也可以这样玩
print("%s 的年龄是 %d, 身高是 %d" % userinfo)
# 还可以这样玩
info = "%s 的年龄是 %d, 身高是 %d" % userinfo
print(info)
元组转列表:list()
列表转元组:tuple()
num_list = [2,1,4,3]
type(num_list) # list
num_tuple = tuple(num_list)
type(num_tuple) # tuple
num_list2 = list(num_tuple)
type(num_list2) # list
Python包括以下元组函数 -
编号 | 函数 | 描述 |
---|---|---|
1 | cmp(tuple1, tuple2) | 比较两个元组的元素。 |
2 | len(tuple) | 给出元组的总长度。 |
3 | max(tuple) | 从元组返回最大值项。 |
4 | min(tuple) | 从元组返回最大值项 |
5 | tuple(seq) | 将列表转换为元组。 |