在Python数据类型中,我们经常会接触到这样一种数据类型,它们的成员是有序排列的,并且能够通过下标偏移量可以访问它的具体的成员,这种Python类型统称为序列,序列主要包括字符串、列表和元组。
序列
序列:一种有序排列的、可以通过下标偏移量进行访问的数据类型。下标偏移量是从0开始到总元素数-1,这种访问形式和我们C语言中的数组的访问形式相同。
序列类型操作符
序列类型操作符主要分为成员关系操作符(in 、not in)、连接操作符(+)、重复操作符(*)、切片操作符([]、[:]、[::])
成员关系操作符(in、not in)
成员关系操作符主要是用来判断一个元素是否属于一个序列的。in/not in操作符的返回值一般来讲是一个布尔值False/True。满足成员关系就返回True,否则返回False。
对象 [not] in 序列
seq = "Hello" # 字符串
'H' in seq True
number = (1,2,3,4,5) # 元组
2 not in number False
连接操作符(+)
通过这个操作符,我们可以简单地把两个相同类型的序列连接成一个新的序列。
sequeue = sequeue1 + sequeue2
注意:这种操作虽然简单,但是比较占用内存,尽量少使用。
sequeue1 = "Hello"
sequeue2 = " Word!"
sequeue = sequeue1 + sequeue2
print sequeue
重复操作符(*)
如果我们需要一个序列的多份拷贝时,这种操作符比较有用。
sequeue * copy_num
# 使用它来做分割线
sequeue = _
sequeue = sequeue * 6
print sequeue
操作符([]、[:]、[::])
序列类型就是包含一些顺序排列的对象的一个结构。我们可以使用[]加下标偏移量来访问一个元素或者[start_index:end_index]访问连续的几个元素或使用[start_index:end_index:num]来间隔num个元素访问序列。
操作符[]
使用这种操作符只能访问一个元素。
sequeue[index]
注意:index是想要访问元素的下标偏移量,偏移量既可以为正,也可以为负。它们的区别在于正索引以序列的开始为起点,负索引是以序列的结束为起点。在使用过程尽量避免访问一个越界的索引,它会引发异常。
names = ['Dava','Joe','Faye','Ammy','Frakle','Talor']
print names[0]
print names[6] # 这是一个越界的索引
Traceback (most recent call last):
File "<pyshell#1>", line 1, in <module>
print names[6]
IndexError: list index out of range
切片操作符[:]
当我们需要同时获取多个元素时,操作符[]就有点力不从心了,虽然它可以实现,但是代码太丑陋了,所以我们就得寻找新的操作符[:]来解决问题。
sequeue[start_index:end_index]
names = ['Dava','Joe','Faye','Ammy','Frakle','Talor']
print names[2:4]
# result
['Faye','Ammy']
如果我们没有提供任何的起始索引和结束索引,它就会访问整个序列。
names = ['Dava','Joe','Faye','Ammy','Frakle','Talor']
# 这种方法和names[0:6]是一样的结果
print names[:]
# result
['Dava', 'Joe', 'Faye', 'Ammy', 'Frakle', 'Talor']
如果我们只是提过起始索引或者结束索引,如果我们只提供起始索引,它会返回从起始索引到index-1的所有元素,如果我们只提供结束索引,它会返回从索引为0到结束索引的元素。
names = ['Dava','Joe','Faye','Ammy','Frakle','Talor']
# 我们只给了起始索引
print names[2:]
# result
['Faye', 'Ammy', 'Frakle', 'Talor']
# 我们只给了结束索引
print names[:3]
# result
['Dava', 'Joe', 'Faye']
切片操作符[::]
操作符[::]比操作符[:]多出来的第三个索引值是用做步长参数的,它和range()里面的步长参数功能相似。
[start_index:end_index:num]
names = ['Dava','Joe','Faye','Ammy','Frakle','Talor']
# 隔一个取一个
print names[2:6:2]
# result
['Faye', 'Frakle']
注意:在序列的操作过程中,我们的打印结果是不包括结束索引所对应的那个元素的。切片索引的语法要比单一元素索引灵活得多,开始和结束索引值可以超过字符串的长度。