python中的列表(list) 切片详解
1.切片:
通过指定下标的方式来获得某一个数据元素,或者通过指定下标范围来获得一组序列的元素,这种访问序列的方式叫做切片。
访问某一个数据元素的的语法如下:
sequence[index] sequence是序列名,index是想要访问的元素对应的偏移量,偏移量可以是正值,范围是:0<=index<=len(sequence)-1;
也可以是负值,范围是:-len(sequence)<=index<=-1
序列访问多个元素,只需给出开始和结束的索引值,并且用冒号分隔就可以了,其语法如下:
sequence[starting_index:ending_index]
通过这种方式我们可以得到从起始索引到结束索引(不包括结束索引对应的元素)之间的一"片"元素.起始索引和结束索引都是可选的,如果没有提供或者用None 作为索引值,切片操作会从序列的最开始处开始,或者直到序列的最末尾结束。
1 2 3 4 5 6 7 8 9 10 11 | li = [ 1 , 2 , 3 , 4 , 5 , 6 , 7 ] print li[ 1 :] #输出[2,3,4,5,6,7],省略终止索引,表示取起始索引之后的所有值,等效于li[1:len(li)] print li[: 3 ] #输出[1,2,3],省略起始索引,表示从0开始取,等效于li[0:3] print li[:] #输出[1,2,3,4,5,6,7],省略起始索引、终止索引、步长值表示取全部,等效于li[0:len(li):1] print li[::] #输出[1,2,3,4,5,6,7],省略起始索引、终止索引、步长值表示取全部,等效于li[0:len(li):1] print li[:: - 1 ] #输出[7,6,5,4,3,2,1],省略起始索引、终止索引,步长值为-1,表示反向获取 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | >>> a = [ 1 , 2 , 3 , 4 , 5 , 6 , 7 ] >>> a[ len (a) - 1 ] 7 >>> a[ - len (a)] 1 >>> a[ len (a)] Traceback (most recent call last): File "<pyshell#98>" , line 1 , in <module> a[ len (a)] IndexError: list index out of range >>> a[ - len (a) - 1 ] Traceback (most recent call last): File "<pyshell#99>" , line 1 , in <module> a[ - len (a) - 1 ] IndexError: list index out of range |
其中a[len(a)-1]等同于a[-1],a[-len(a)]等同于a[0],分别表示序列的最后一个和第一个对象。
当使用冒号(:)对序列进行切片取值时,你所输入的无论是start_index或者end_index,都不必局限于 -len(a) 和 len(a)-1 之间,因为只有当你输入的索引号处于这个区间时才真正有效,而当你输入的索引号超出这个范围时,python会自动将start_index或end_index设定为缺省值(即第一个对象和最后一个对象)。如:
1 2 | >>> a[ - 100 : 100 ] [ 1 , 2 , 3 , 4 , 5 , 6 , 7 ] |
1 2 3 4 | [注意]一定要记住,end_index其实是你第一个不想要获取的对象的索引,所以a[ 0 : - 1 ]是取不到a[ - 1 ]的,所以如果要使得切片片段包含end_index位置的对象,请缺省end_index,或者输入一个超出end_index范围的值。 利用步长对序列进行倒序取值 在切片运算中,步长为正,表示从左至右,按照索引值与起始位置索引之差可以被步长整除的规律取值;当步长为负,则表示从右至左,按照按照索引值与起始位置索引之差可以被步长整除的规律取值。 根据这个特性,我们可以很方便对某个序列进行倒序取值,这个方法比reverse方法更方便,且适用于没有reverse方法的字符串和元组。 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 | >>> a = [ 1 , 2 , 3 , 4 , 5 , 6 , 7 ] >>> b = ( 1 , 2 , 3 , 4 , 5 , 6 , 7 ) >>> c = 'Let me show you a little thing' >>> a[:: - 1 ] [ 7 , 6 , 5 , 4 , 3 , 2 , 1 ] >>> b[:: - 1 ] ( 7 , 6 , 5 , 4 , 3 , 2 , 1 ) >>> c[:: - 1 ] 'gniht elttil a uoy wohs em teL' >>> a [ 1 , 2 , 3 , 4 , 5 , 6 , 7 ] >>> b ( 1 , 2 , 3 , 4 , 5 , 6 , 7 ) >>> c 'Let me show you a little thing' >>> a.reverse() >>> a [ 7 , 6 , 5 , 4 , 3 , 2 , 1 ] |
好记忆不如烂笔头
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术