1.序列(sequence):
说明:在前面的字符串列表中其实我们已经用到了序列,之所以放到这篇来讲主要是为了承上启下,方便理解和记忆。
python的数据访问模型:直接存取 ,序列 ,映射
- 对非容器类都可以直接存取,所有的数值类型归为此类。
- 序列类型是指容器内的元素从0开始的索引顺序访问,一次可以访问一个或者多个元素。 字符串、列表、元组归到次类
- 映射类型和序列类型不同之处,它使用的索引和顺序的数字偏移量不同,它的元素无序存放,通过唯一的key来访问。 字典就是这种类型。
2.Python 元组
Python的元组与列表类似,不同之处在于元组的元素不能修改。
2.1 创建元组
元组使用小括号,列表使用方括号。
元组创建很简单,只需要在括号中添加元素,并使用逗号隔开即可。
示例1:
#!/usr/bin/env python # -*- coding: utf-8 -*- # @Time : 2016/9/11 20:54 # @Author : wwyx tup1 = ("python", "java", "c", "c++") tup2 = ("德玛西亚", "诺克萨斯", "艾欧呢呀") tup3 = ("提款姬", "托儿索", "儿童劫", "娃娃鱼", "小学僧") print "tup1 如下 :" for var1 in tup1: print var1 print "tup2 如下 :" for var2 in tup2: print var2 print "tup3 如下:" for var3 in tup3: print var3
示例1 运行结果:
tup1 如下 : python java c c++ tup2 如下 : 德玛西亚 诺克萨斯 艾欧呢呀 tup3 如下: 提款姬 托儿索 儿童劫 娃娃鱼 小学僧
2.2创建空元组
元组中只包含一个元素时,需要在元素后面添加逗号
元组与字符串类似,下标索引从0开始,可以进行截取,组合等。
示例2
#!/usr/bin/env python # -*- coding: utf-8 -*- # @Time : 2016/9/11 20:54 # @Author : wwyx tup1 = () #创建空元组 tup2 = ("艾欧呢呀",) #创建一个元组 print tup1 print tup2[0]
示例2 运行结果:
() 艾欧呢呀
注:元组中的元素遍历根据序列的遍历方法遍历,如果直接打印 如上例中的 tup2 则会返回 tup2 在内存中的表示
2.3访问元组
- 元组的访问可以通过for迭代来访问,如示例1
- 元组的访问也可以通过序列的索引来遍历,如示例2
2.4修改元组
注:元组中的元素值是不允许修改的,但我们可以对元组进行连接组合.
示例3:
#!/usr/bin/env python # -*- coding: utf-8 -*- # @Time : 2016/9/11 20:54 # @Author : wwyx tup1 = ("python", "java", "c", "c++") tup2 = ("德玛西亚", "诺克萨斯", "艾欧呢呀") tup3 = ("提款姬", "托儿索", "儿童劫", "娃娃鱼", "小学僧") tup4 = tup1 + tup2 + tup3 print "tup4 如下:" for var1 in tup4: print var1
示例3 运行结果
tup4 如下: python java c c++ 德玛西亚 诺克萨斯 艾欧呢呀 提款姬 托儿索 儿童劫 娃娃鱼 小学僧
2.5删除元组
注:元组中的元素值是不允许删除的,但我们可以使用del语句来删除整个元组
示例4
tup2 = ("德玛西亚", "诺克萨斯", "艾欧呢呀") tup3 = ("提款姬", "托儿索", "儿童劫", "娃娃鱼", "小学僧") print "tup2如下:" for var1 in tup2: print var1 del tup2 print "删除后的 tup2如下:" print tup2[2] del tup3[2] # 删除tup3的索引为2的元素
示例4 运行结果
tup2如下: Traceback (most recent call last): 德玛西亚 File "E:/python/hello/untitled3/tuple.py", line 14, in <module> 诺克萨斯 print tup2[2] 艾欧呢呀 NameError: name 'tup2' is not defined 删除后的 tup2如下:
3.元组运算符
与字符串一样,元组之间可以使用 + 号和 * 号进行运算。这就意味着他们可以组合和复制,运算后会生成一个新的元组。
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, | 1 2 3 | 迭代 |
4.元组索引,截取
因为元组也是一个序列,所以我们可以访问元组中的指定位置的元素,也可以截取索引中的一段元素,如下所示:
元组:
L = ('spam', 'Spam', 'SPAM!')
Python 表达式 | 结果 | 描述 |
---|---|---|
L[2] | 'SPAM!' | 读取第三个元素 |
L[-2] | 'Spam' | 反向读取;读取倒数第二个元素 |
L[1:] | ('Spam', 'SPAM!') | 截取元素 |
5.无关闭分隔符
任意无符号的对象,以逗号隔开,默认为元组,
示例5
print "提款姬", "托儿索", "儿童劫", "娃娃鱼", "小学僧" print "提莫队长", 1, 2, 3, 4
示例5运行结果
提款姬 托儿索 儿童劫 娃娃鱼 小学僧 提莫队长 1 2 3 4
注:记住这一条,尽量自己不要用,在一个为了能顺利看懂别人代码
6. 元组内置函数
Python元组常用内置函数:
序号 | 方法及描述 |
---|---|
1 |
cmp(tuple1, tuple2) 比较两个元组元素。 |
2 |
len(tuple) 计算元组元素个数。 |
3 |
max(tuple) 返回元组中元素最大值。 |
4 |
min(tuple) 返回元组中元素最小值。 |
5 |
tuple(seq) 将列表转换为元组。 |
示例6
#!/usr/bin/env python # -*- coding: utf-8 -*- # @Time : 2016/9/11 20:54 # @Author : wwyx # tup1 = ("python", "java", "c", "c++") tup2 = ("德玛西亚", "诺克萨斯", "艾欧呢呀") tup3 = ("提款姬", "托儿索", "儿童劫", "娃娃鱼", "小学僧") var1 = cmp(tup2, tup3) print "tup2 和 tup3 对比结果:", var1 print "tup2 的 最大值:", max(tup2) print "tup3 的最小值:", min(tup3)
示例6 运行结果:
tup2 和 tup3 对比结果: -1 tup2 的 最大值: 诺克萨斯 tup3 的最小值: 儿童劫
好了,元组就说到这里,下一篇字典,加油!!