标签:most ack file 访问 运算符 字符 bin image last
元组:tuple。tuple和list非常类似,但是tuple一旦初始化就不能修改
元组使用小括号,列表使用方括号。
元组创建很简单,只需要在括号中添加元素,并使用逗号隔开即可。
如下实例:
1 tup1 = (‘Google‘, ‘Runoob‘, 1997, 2000); 2 tup2 = (1, 2, 3, 4, 5 ); 3 tup3 = "a", "b", "c", "d";
创建空元组:
1 tup1 = ();
注意:元组中只包含一个元素时,需要在元素后面添加逗号,否则括号会被当作运算符使用
1 >>> tup1 = (50) 2 >>> type(tup1) # 不加逗号,类型为整型 3 <class ‘int‘> 4 5 >>> tup1 = (50,) 6 >>> type(tup1) # 加上逗号,类型为元组 7 <class ‘tuple‘>
元组与字符串类似,下标索引从0开始,可以进行截取,组合等。
来看一个“可变的”tuple:
1 >>> t = (‘a‘, ‘b‘, [‘A‘, ‘B‘]) 2 >>> t[2][0] = ‘X‘ 3 >>> t[2][1] = ‘Y‘ 4 >>> t 5 (‘a‘, ‘b‘, [‘X‘, ‘Y‘])
不是说tuple一旦定义后就不可变了吗?怎么后来又变了?
表面上看,tuple的元素确实变了,但其实变的不是tuple的元素,而是list的元素。tuple一开始指向的list并没有改成别的list,所以,tuple所谓的“不变”是说,tuple的每个元素,指向永远不变。即指向‘a‘
,就不能改成指向‘b‘
,指向一个list,就不能改成指向其他对象,但指向的这个list本身是可变的!
理解了“指向不变”后,要创建一个内容也不变的tuple怎么做?那就必须保证tuple的每一个元素本身也不能变。
元组可以使用下标索引来访问元组中的值,如下实例:
1 #!/usr/bin/python3 2 3 tup1 = (‘Google‘, ‘Runoob‘, 1997, 2000) 4 tup2 = (1, 2, 3, 4, 5, 6, 7 ) 5 6 print ("tup1[0]: ", tup1[0]) 7 print ("tup2[1:5]: ", tup2[1:5])
以上实例输出结果:
1 tup1[0]: Google 2 tup2[1:5]: (2, 3, 4, 5)
元组中的元素值是不允许修改的,但我们可以对元组进行连接组合,如下实例:
1 #!/usr/bin/python3 2 3 tup1 = (12, 34.56); 4 tup2 = (‘abc‘, ‘xyz‘) 5 6 # 以下修改元组元素操作是非法的。 7 # tup1[0] = 100 8 9 # 创建一个新的元组 10 tup3 = tup1 + tup2; 11 print (tup3)
以上实例输出结果:
1 (12, 34.56, ‘abc‘, ‘xyz‘)
元组中的元素值是不允许删除的,但我们可以使用del语句来删除整个元组,如下实例:
1 #!/usr/bin/python3 2 3 tup = (‘Google‘, ‘Runoob‘, 1997, 2000) 4 5 print (tup) 6 del tup; 7 print ("删除后的元组 tup : ") 8 print (tup)
以上实例元组被删除后,输出变量会有异常信息,输出如下所示:
1 删除后的元组 tup : 2 Traceback (most recent call last): 3 File "test.py", line 8, in <module> 4 print (tup) 5 NameError: name ‘tup‘ is not defined
与字符串一样,元组之间可以使用 + 号和 * 号进行运算。这就意味着他们可以组合和复制,运算后会生成一个新的元组。
因为元组也是一个序列,所以我们可以访问元组中的指定位置的元素,也可以截取索引中的一段元素,如下所示:
元组:
1 L = (‘Google‘, ‘Taobao‘, ‘Runoob‘)
运行实例如下:
1 >>> L = (‘Google‘, ‘Taobao‘, ‘Runoob‘) 2 >>> L[2] 3 ‘Runoob‘ 4 >>> L[-2] 5 ‘Taobao‘ 6 >>> L[1:] 7 (‘Taobao‘, ‘Runoob‘)
Python元组包含了以下内置函数
标签:most ack file 访问 运算符 字符 bin image last
原文地址:http://www.cnblogs.com/jiyimeng/p/python11111.html