1、取一个list的部分元素是非常常见的操作,Python提供了切片(Slice)操作符
L[0:3]表示,从索引0开始取,直到索引3为止,但不包括索引3。即索引0,1,2,正好是3个元素。
如果第一个索引是0,还可以省略:
也可以从索引1开始,取出2个元素出来:
只用一个 : ,表示从头到尾,因此,L[:]实际上复制出了一个新list。
切片操作还可以指定第三个参数:L[::2]
第三个参数表示每N个取一个,上面的 L[::2] 会每两个元素取出一个来,也就是隔一个取一个。
把list换成tuple,切片操作完全相同,只是切片的结果也变成了tuple。
L = [1, 2, 3, 4, 5] print L[0:3] # ==> [1, 2, 3] print L[:3] # ==> [1, 2, 3] print L[::2] # ==> [1, 3, 5] L = (1, 2, 3, 4, 5) print L[0:3] # ==> (1, 2, 3) print L[:3] # ==> (1, 2, 3) print L[::2] # ==> (1, 3, 5)
2、倒序切片
对于list,既然Python支持L[-1]取倒数第一个元素,那么它同样支持倒数切片
L = [1, 2, 3, 4, 5] print L[:-3] # ==> [1, 2] print L[-3:] # ==> [3, 4, 5] print L[-3:-1] # ==> [3, 4] print L[:-1:2] # ==> [1, 3]
记住倒数第一个元素的索引是-1。倒序切片包含起始索引,不包含结束索引。
3、对字符串切片
字符串 'xxx'和 Unicode字符串 u'xxx'也可以看成是一种list,每个元素就是一个字符。因此,字符串也可以用切片操作,只是操作结果仍是字符串
S = 'ABCDEFG' print S[:3] # ==> 'ABC' print S[1:3] # ==> 'BC' print S[1::2] # ==> 'BDF'
在很多编程语言中,针对字符串提供了很多各种截取函数,其实目的就是对字符串切片。Python没有针对字符串的截取函数,只需要切片一个操作就可以完成,非常简单。
示例:
# 将首字母变为大写 def firstCharUpper(s): return s[:1].upper()+s[1:] print firstCharUpper('hello') # ==> Hello print firstCharUpper('sunday') # ==> Sunday print firstCharUpper('september') # ==> September