• 对list进行切片
  • 倒序切片
  • 对字符串切片


对list进行切片

取一个list或tuple的部分元素是非常常见的操作。比如,一个list如下:

L = ['A', 'B', 'C', 'D']

取前3个元素,应该怎么做?

最笨的办法是一次取出前3个元素,再通过这3个元素组成一个新的list。但是如果现在要去前N个元素就没辙了。

取前N个元素,也就是索引为0-(N-1)的元素,可以用循环:

>>> r = []
>>> n = 3
>>> for i in range(n):
        r.append(L[i])
>>> r
['A', 'B', 'C']

PS: range()函数可以创建一个数列:

>>> range(1, 101)
[1, 2, 3, ..., 100]

对这种经常取指定索引范围的操作,用循环十分繁琐,因此,Python提供了切片(Slice)操作符,能大大简化这种操作。

对应上面的问题,取前3个元素,用一行代码就可以完成切片:

>>> L[0:3]
['A', 'B', 'C']

L[0:3]表示,从索引0开始取,直到索引3为止,但不包括索引3。即索引0,1,2,正好是3个元素。

如果第一个索引是0,还可以省略:

>>> L[:3]
['A', 'B', 'C']

只用一个 : ,表示从头到尾:

>>> L[:]
['A', 'B', 'C', 'D']

因此,L[:]实际上复制出了一个新list。

也可以从索引start开始,到end,取出其中元素出来:

>>>L[start:end]

切片操作还可以指定第三个参数:

>>> L[::2]
['A', 'C']

第三个参数表示每N个取一个,上面的 L[::2] 会每两个元素取出一个来,也就是隔一个取一个。

把list换成tuple,切片操作完全相同,只是切片的结果也变成了tuple。

Example:利用切片,取出:
1. 前10个数;
2. 3的倍数;
3. 不大于50的5的倍数。

L = range(1, 101)

print L[:10]#从第1个数元素开始取,到第11元素结束
print L[2::3]#从第三元素开始取,每隔2个取一个元素
print L[4:50:5]#从第五个取,每隔4个取一个,‘开始元素’:‘最后元素’:‘取元素间隔’

倒序切片

对于list,既然Python支持L[-1]取倒数第一个元素,那么它同样支持倒数切片,试试:

>>> L[-2:]
['C', 'D']
>>> L[-2:-1]
['C']

记住倒数第一个元素的索引是-1。倒序切片包含起始索引,不包含结束索引。

For Example:

利用倒序切片对 1 - 100 的数列取出:1、最后10个数;2、最后10个5的倍数。

L = range(1, 101)
print L[-10:]
print L[4::5][-10:]#先取出5的倍数,再取最后10个

对字符串切片

字符串 ‘xxx’和 Unicode字符串 u’xxx’也可以看成是一种list,每个元素就是一个字符。因此,字符串也可以用切片操作,只是操作结果仍是字符串:

>>> 'ABCDEFG'[:3]
'ABC'
>>> 'ABCDEFG'[-3:]
'EFG'
>>> 'ABCDEFG'[::2]
'ACEG'

在很多编程语言中,针对字符串提供了很多各种截取函数(例如,substring),其实目的就是对字符串切片。Python没有针对字符串的截取函数,只需要切片一个操作就可以完成,非常简单。

example:请设计一个函数,它接受一个字符串,然后返回一个仅首字母变成大写的字符串。

字符串有个方法 upper() 可以把字符变成大写字母:

>>> 'abc'.upper()
'ABC'

code如下:

def firstCharUpper(s):
return s[:1].upper()+s[1:]#取出首字母转换为大写,再拼接后面的字符串

print firstCharUpper('hello')
print firstCharUpper('sunday')
print firstCharUpper('september')