對(duì)list進(jìn)行切片在python
提問(wèn)人:楊紫紅發(fā)布時(shí)間:2020-11-26
取一個(gè)list的部分元素是非常常見(jiàn)的操作。比如,一個(gè)list如下:
>>> L = ['Adam', 'Lisa', 'Bart', 'Paul']
取前3個(gè)元素,應(yīng)該怎么做?
笨辦法:
>>> [L[0], L[1], L[2]]
['Adam', 'Lisa', 'Bart']
之所以是笨辦法是因?yàn)閿U(kuò)展一下,取前N個(gè)元素就沒(méi)轍了。
取前N個(gè)元素,也就是索引為0-(N-1)的元素,可以用循環(huán):
>>> r = []
>>> n = 3
>>> for i in range(n):
... r.append(L[i])
...
>>> r
['Adam', 'Lisa', 'Bart']
對(duì)這種經(jīng)常取指定索引范圍的操作,用循環(huán)十分繁瑣,因此,Python提供了切片(Slice)操作符,能大大簡(jiǎn)化這種操作。
對(duì)應(yīng)上面的問(wèn)題,取前3個(gè)元素,用一行代碼就可以完成切片:
>>> L[0:3]
['Adam', 'Lisa', 'Bart']
L[0:3]表示,從索引0開(kāi)始取,直到索引3為止,但不包括索引3。即索引0,1,2,正好是3個(gè)元素。
如果第一個(gè)索引是0,還可以省略:
>>> L[:3]
['Adam', 'Lisa', 'Bart']
也可以從索引1開(kāi)始,取出2個(gè)元素出來(lái):
>>> L[1:3]
['Lisa', 'Bart']
只用一個(gè) : ,表示從頭到尾:
>>> L[:]
['Adam', 'Lisa', 'Bart', 'Paul']
因此,L[:]實(shí)際上復(fù)制出了一個(gè)新list。
切片操作還可以指定第三個(gè)參數(shù):
>>> L[::2]
['Adam', 'Bart']
第三個(gè)參數(shù)表示每N個(gè)取一個(gè),上面的 L[::2] 會(huì)每?jī)蓚€(gè)元素取出一個(gè)來(lái),也就是隔一個(gè)取一個(gè)。
把list換成tuple,切片操作完全相同,只是切片的結(jié)果也變成了tuple。
>>> L = ['Adam', 'Lisa', 'Bart', 'Paul']
取前3個(gè)元素,應(yīng)該怎么做?
笨辦法:
>>> [L[0], L[1], L[2]]
['Adam', 'Lisa', 'Bart']
之所以是笨辦法是因?yàn)閿U(kuò)展一下,取前N個(gè)元素就沒(méi)轍了。
取前N個(gè)元素,也就是索引為0-(N-1)的元素,可以用循環(huán):
>>> r = []
>>> n = 3
>>> for i in range(n):
... r.append(L[i])
...
>>> r
['Adam', 'Lisa', 'Bart']
對(duì)這種經(jīng)常取指定索引范圍的操作,用循環(huán)十分繁瑣,因此,Python提供了切片(Slice)操作符,能大大簡(jiǎn)化這種操作。
對(duì)應(yīng)上面的問(wèn)題,取前3個(gè)元素,用一行代碼就可以完成切片:
>>> L[0:3]
['Adam', 'Lisa', 'Bart']
L[0:3]表示,從索引0開(kāi)始取,直到索引3為止,但不包括索引3。即索引0,1,2,正好是3個(gè)元素。
如果第一個(gè)索引是0,還可以省略:
>>> L[:3]
['Adam', 'Lisa', 'Bart']
也可以從索引1開(kāi)始,取出2個(gè)元素出來(lái):
>>> L[1:3]
['Lisa', 'Bart']
只用一個(gè) : ,表示從頭到尾:
>>> L[:]
['Adam', 'Lisa', 'Bart', 'Paul']
因此,L[:]實(shí)際上復(fù)制出了一個(gè)新list。
切片操作還可以指定第三個(gè)參數(shù):
>>> L[::2]
['Adam', 'Bart']
第三個(gè)參數(shù)表示每N個(gè)取一個(gè),上面的 L[::2] 會(huì)每?jī)蓚€(gè)元素取出一個(gè)來(lái),也就是隔一個(gè)取一個(gè)。
把list換成tuple,切片操作完全相同,只是切片的結(jié)果也變成了tuple。
繼續(xù)查找其他問(wèn)題的答案?
相關(guān)視頻回答
點(diǎn)擊加載更多評(píng)論>>