Python基础8切片

来源:互联网 发布:诸葛亮知风 编辑:程序博客网 时间:2024/05/24 06:19

环境:eclipsepython2.7

1 list进行切片

1.1 方法一取前n个元素

#-*- coding: utf-8 -*-L = ['Adam', 'Lisa', 'Bart', 'Paul']t = [L[0], L[1], L[2]]print t#['Adam', 'Lisa', 'Bart']

1.2 方法二利用for循环

range([a,]b [,c])函数,a可选表示起始值,默认为0b表示最终值;c表示步长

#-*- coding: utf-8 -*-L = ['Adam', 'Lisa', 'Bart', 'Paul']r = []n = 3for i in range(n):    r.append(L[i])print r#['Adam', 'Lisa', 'Bart']

1.3 方法三 利用切片实现

L[a,b,c]其中,a表示起始列表L的起始位置,默认为0b表示结束位置,默认为L的最后一个元素;c表示步长,可选。

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

L = ['Adam', 'Lisa', 'Bart', 'Paul']s =  L[0:3]print s#['Adam', 'Lisa', 'Bart']

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

s =  L[:3]print s#['Adam', 'Lisa', 'Bart']

3)也可以从索引1开始,取出2个元素出来:

s =  L[1:3]print s#['Lisa', 'Bart']

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

s =  L[:]print s#['Adam', 'Lisa', 'Bart', 'Paul']

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

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

s =  L[::2]print s#['Adam', 'Bart']

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

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

2 倒序切片

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

#-*- coding: utf-8 -*-L = ['Adam', 'Lisa', 'Bart', 'Paul']print L[-2:]print L[:-2]print L[-3:-1]print L[-4:-1:2]

输出:

['Bart', 'Paul']

['Adam', 'Lisa']

['Lisa', 'Bart']

['Adam', 'Bart']

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

例题:

利用倒序切片对 1 - 100 的数列取出:

最后10个数;

最后105的倍数。

#-*- coding: utf-8 -*-L = range(1, 101)print L[-10:]print L[-46::5]

3 对字符串切片

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

#-*- coding: utf-8 -*-print 'ABCDEFG'[:3]#ABCprint 'ABCDEFG'[-3:]#EFGprint 'ABCDEFG'[::2]#ACEG

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

例题:字符串有个方法 upper() 可以把字符变成大写字母:'abc'.upper()但它会把所有字母都变成大写。请设计一个函数,它接受一个字符串,然后返回一个仅首字母变成大写的字符串。

#-*- coding: utf-8 -*-def firstCharUpper(s):    return s.upper()[:1]+s[1:]print firstCharUpper('hello')#Hello

0 0