Python:切片

本文介绍了Python中的切片操作,包括如何使用切片获取list、tuple和字符串的部分元素。通过[L:x:y]的方式,可以指定起始索引、结束索引(不包含)和步长。还探讨了倒序切片以及在字符串操作中的应用,并给出了相关任务实例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

>>> L = ['Adam', 'Lisa', 'Bart', 'Paul']

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

笨办法:

>>> [L[0], L[1], L[2]]
['Adam', 'Lisa', 'Bart']

之所以是笨办法是因为扩展一下,取前N个元素就没辙了。

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

>>> r = []
>>> n = 3
>>> for i in range(n):
...     r.append(L[i])
... 
>>> r
['Adam', 'Lisa', 'Bart']

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

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

>>> L[0:3]
['Adam', 'Lisa', 'Bart']

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

如果第一个索引是0,还可以省略:也就是省略不填时默认为0

>>> L[:3]
['Adam', 'Lisa', 'Bart']

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

>>> L[1:3]
['Lisa', 'Bart']

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

>>> L[:]
['Adam', 'Lisa', 'Bart', 'Paul']

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

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

>>> L[::2]
['Adam', 'Bart']

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

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

总结:[x:y:z]第一个值为起始索引,第二个为终点索引,第三个为间隔数。

任务

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

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

请利用切片,取出:

1. 前10个数;
2. 3的倍数;
3. 不大于50的5的倍数。

要取出3, 6, 9可以用::3的操作,但是要确定起始索引。

参考代码:

L = range(1, 101)
print L[:10]
print L[2::3]
print L[4:50:5]

倒序切片

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

>>> L = ['Adam', 'Lisa', 'Bart', 'Paul']

>>> L[-2:]    #索引:-2取到0不包含0.
['Bart', 'Paul']

>>> L[:-2]    #索引:0取到-2不包含-2.
['Adam', 'Lisa']

>>> L[-3:-1]   #索引:-3取到-1不包含-1.
['Lisa', 'Bart']

>>> L[-4:-1:2]  #索引:-4取到-1,不包含-1,索引值+2取一次。.
['Adam', 'Bart']

 

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

任务

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

* 最后10个数;

* 最后10个5的倍数。

5的倍数可以用 ::5 取出,要确定起始索引。

参考代码:

L = range(1, 101)
print L[-10:]
print L[-46::5]

对字符串切片

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

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

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

任务

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

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

但它会把所有字母都变成大写。请设计一个函数,它接受一个字符串,然后返回一个仅首字母变成大写的字符串。

提示:利用切片操作简化字符串操作。

取除首字母外的字符串用[1:]

参考代码:

def firstCharUpper(s):
    return s[0].upper() + s[1:]   #先取出首个字母,并转换为大写,然后再用切片取出后续字母
print firstCharUpper('hello')
print firstCharUpper('sunday')
print firstCharUpper('september')
Python中,切片(slice)是种高级索引方法,用于从序列对象(如list, string, tuple)中取出个范围对应的元素。它通过指定起始位置、结束位置和步长来实现对序列的切割操作。 切片的索引方式可以使用冒号来表示范围,起始位置和结束位置都可以省略。例如,对于个元组t=(1,2,3,4,5),可以使用t[1:3]来获取索引为1到索引为2的元素,即(2,3)。同样地,对于个字符串s="ACDRF",可以使用s[1:3]来获取索引为1到索引为2的字符,即"CD"。 除了基本的序列类型,切片操作还可以应用于其他对象。比如,可以对元组进行切片操作,例如(0, 1, 2, 3, 4, 5)[:3]将返回(0, 1, 2)。还可以在for循环中使用切片操作,比如for i in range(0,100)[2::3][-10:]可以从列表中取出从第二位开始,步长为3的元素,并从倒数第10位开始取10个元素。 切片操作的详细切法有以下几个参数:start表示切片的起始位置,默认为序列的开头;end表示切片的结束位置,但包含该位置的元素,如果没有指定则表示切割到序列的结束;step表示步长,默认值为1,如果步长为正数,则表示从左往右取元素,如果为负数,则表示从右往左取元素。 综上所述,Python中的切片操作可以实现对序列对象的灵活切割,通过指定起始位置、结束位置和步长来获取所需的元素范围。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Python中的切片(详细篇)学起来喔](https://blog.youkuaiyun.com/Zombie_QP/article/details/125063501)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值