定义一个list:
L = ['haha','xixi','hehe','heihei','gaga']取其前三个元素:
>>> L[0],L[1],L[2] ('haha', 'xixi', 'hehe')这个方法有点蠢,因为如果元素非常多,我们需要取其前N个元素,怎么办?
可能会想到用循环:
''' 遇到问题没人解答?小编创建了一个Python学习交流QQ群:778463939 寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书! ''' >>> r=[] >>> n = 3 >>> for i in range(n): ... r.append(L[i]) ... >>> r ['haha', 'xixi', 'hehe']但是像这种很频繁很常用的操作手段,基本上所有的语言都提供了简单的操作方法,类似Substring方法(俗称取子串),python也提供了类似的方法,这就是切片(Slice).
例如:
>>> L[0:3] ['haha', 'xixi', 'hehe']其中,L[0:3]表示从索引0开始,知道索引3为止,但是不包括索引3,即索引0,1,2.
如果第一个索引为0,还可以省略:
>>> L[:3] ['haha', 'xixi', 'hehe']也可以从任意索引开始:
>>> L[1:2] ['xixi']也可以试试:
>>> L[1:1] []因为,Python也支持倒数取数L[-1],我们来看看是否支持倒数切片:(记住,倒数第一个索引是-1)
''' 遇到问题没人解答?小编创建了一个Python学习交流QQ群:778463939 寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书! ''' >>> L[-2:] ['heihei', 'gaga'] >>> L[-3:-2] ['hehe']如果感觉还不过瘾,再继续看看:
>>> m = list(range(100))#通过range函数创建一个0-99的数列,组成一个list赋值给m >>> m [0, 1, 2, 3, 4, 5, 6, ……,99] ''' 遇到问题没人解答?小编创建了一个Python学习交流QQ群:778463939 寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书! ''' >>> m[:10]#取前十个数 [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] >>> m[-10:]#取后十个数 [90, 91, 92, 93, 94, 95, 96, 97, 98, 99] >>> m[10:20]#取前11-20个数 [10, 11, 12, 13, 14, 15, 16, 17, 18, 19] >>> m[:10:2]#前十个数中,每2个数取一个 [0, 2, 4, 6, 8] >>> m[5:15:3]#第6-15个数中,每3个数取一个 [5, 8, 11, 14] >>> m[::10]#所有的数中,每10个数取一个 [0, 10, 20, 30, 40, 50, 60, 70, 80, 90] >>> m[:]#什么都不写,可以原样复制一个list [0, 1, 2, 3, 4, 5, 6, 7,……,99]tuple也支持切片特性,只是结果也是一个tuple:
>>> n = (1,3,5,7) >>> n[:3] (1, 3, 5)再来看看字符串:
>>> 'abcdefghjklmn'[::2] 'acegjln'字符串也支持切片,只是结果也是一个字符串。
再看一个例子:
利用切片功能,编写一个函数trim(str),类似Python中的strip()功能——去除字符串首尾的空格:
>>> def trim(str): ... while str[:1]==' ': ... str = str[1:] ... while str[-1:] == ' ': ... str = str[:-2] ... return str ... >>> trim(' abc hh welcome! ') 'abc hh welcome!'