如何在Python中使用切片-創(chuàng)新互聯(lián)

這篇文章給大家介紹如何在Python中使用切片,內(nèi)容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

贛榆網(wǎng)站建設(shè)公司創(chuàng)新互聯(lián)公司,贛榆網(wǎng)站設(shè)計制作,有大型網(wǎng)站制作公司豐富經(jīng)驗。已為贛榆上1000+提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\成都外貿(mào)網(wǎng)站建設(shè)公司要多少錢,請找那個售后服務(wù)好的贛榆做網(wǎng)站的公司定做!

1、切片的基礎(chǔ)用法

列表是 Python 中極為基礎(chǔ)且重要的一種數(shù)據(jù)結(jié)構(gòu),我曾寫過一篇匯總文章(鏈接見文末)較全面地學(xué)習(xí)過它。文中詳細地總結(jié)了切片的基礎(chǔ)用法,現(xiàn)在回顧一下:

切片的書寫形式:[i : i+n : m] ;其中,i 是切片的起始索引值,為列表首位時可省略;i+n 是切片的結(jié)束位置,為列表末位時可省略;m 可以不提供,默認值是1, 不允許為0 ,當(dāng)m為負數(shù)時,列表翻轉(zhuǎn)。注意:這些值都可以大于列表長度,不會報越界。

切片的基本含義是: 從序列的第i位索引起,向右取到后n位元素為止,按m間隔過濾 。

li = [1, 4, 5, 6, 7, 9, 11, 14, 16]

# 以下寫法都可以表示整個列表,其中 X >= len(li)
li[0:X] == li[0:] == li[:X] == li[:] == li[::] == li[-X:X] == li[-X:]

li[1:5] == [4,5,6,7] # 從1起,取5-1位元素
li[1:5:2] == [4,6] # 從1起,取5-1位元素,按2間隔過濾
li[-1:] == [16] # 取倒數(shù)第一個元素
li[-4:-2] == [9, 11] # 從倒數(shù)第四起,取-2-(-4)=2位元素
li[:-2] == li[-len(li):-2] == [1,4,5,6,7,9,11] # 從頭開始,取-2-(-len(li))=7位元素

# 步長為負數(shù)時,列表先翻轉(zhuǎn),再截取
li[::-1] == [16,14,11,9,7,6,5,4,1] # 翻轉(zhuǎn)整個列表
li[::-2] == [16,11,7,5,1] # 翻轉(zhuǎn)整個列表,再按2間隔過濾
li[:-5:-1] == [16,14,11,9] # 翻轉(zhuǎn)整個列表,取-5-(-len(li))=4位元素
li[:-5:-3] == [16,9] # 翻轉(zhuǎn)整個列表,取-5-(-len(li))=4位元素,再按3間隔過濾

# 切片的步長不可以為0
li[::0] # 報錯(ValueError: slice step cannot be zero)

上述的某些例子對于初學(xué)者(甚至很多老手)來說,可能還不好理解。我個人總結(jié)出兩條經(jīng)驗:(1)牢牢記住公式 [i : i+n : m] ,當(dāng)出現(xiàn)缺省值時,通過想象把公式補全;(2)索引為負且步長為正時,按倒數(shù)計算索引位置;索引為負且步長為負時,先翻轉(zhuǎn)列表,再按倒數(shù)計算索引位置。

2、切片是偽獨立對象

切片操作的返回結(jié)果是一個新的獨立的序列(PS:也有例外,參見《 Python是否支持復(fù)制字符串呢? 》)。以列表為例,列表切片后得到的還是一個列表,占用新的內(nèi)存地址。

當(dāng)取出切片的結(jié)果時,它是一個獨立對象,因此,可以將其用于賦值操作,也可以用于其它傳遞值的場景。但是,切片只是淺拷貝,它拷貝的是原列表中元素的引用,所以,當(dāng)存在變長對象的元素時,新列表將受制于原列表。

li = [1, 2, 3, 4]
ls = li[::]

li == ls # True
id(li) == id(ls) # False
li.append(li[2:4]) # [1, 2, 3, 4, [3, 4]]
ls.extend(ls[2:4]) # [1, 2, 3, 4, 3, 4]

# 下例等價于判斷l(xiāng)i長度是否大于8
if(li[8:]):
  print("not empty")
else:
  print("empty")

# 切片列表受制于原列表
lo = [1,[1,1],2,3]
lp = lo[:2] # [1, [1, 1]]
lo[1].append(1) # [1, [1, 1, 1], 2, 3]
lp # [1, [1, 1, 1]]

由于可見,將切片結(jié)果取出,它可以作為獨立對象使用,但是也要注意,是否取出了變長對象的元素。

3、切片可作為占位符

切片既可以作為獨立對象被“取出”原序列,也可以留在原序列,作為一種占位符使用。

在寫《 詳解Python拼接字符串的七種方式 》的時候,我介紹了幾種拼接字符串的方法,其中三種格式化類的拼接方法(即 %、format()、template)就是使用了占位符的思想。對于列表來說,使用切片作為占位符,同樣能夠?qū)崿F(xiàn)拼接列表的效果。特別需要注意的是,給切片賦值的必須是可迭代對象。

li = [1, 2, 3, 4]

# 在頭部拼接
li[:0] = [0] # [0, 1, 2, 3, 4]
# 在末尾拼接
li[len(li):] = [5,7] # [0, 1, 2, 3, 4, 5, 7]
# 在中部拼接
li[6:6] = [6] # [0, 1, 2, 3, 4, 5, 6, 7]

# 給切片賦值的必須是可迭代對象
li[-1:-1] = 6 # (報錯,TypeError: can only assign an iterable)
li[:0] = (9,) # [9, 0, 1, 2, 3, 4, 5, 6, 7]
li[:0] = range(3) # [0, 1, 2, 9, 0, 1, 2, 3, 4, 5, 6, 7]

上述例子中,若將切片作為獨立對象取出,那你會發(fā)現(xiàn)它們都是空列表,即 li[:0]==li[len(li):]==li[6:6]==[] ,我將這種占位符稱為“ 純占位符 ”,對純占位符賦值,并不會破壞原有的元素,只會在特定的索引位置中拼接進新的元素。刪除純占位符時,也不會影響列表中的元素。

與“純占位符”相對應(yīng),“ 非純占位符 ”的切片是非空列表,對它進行操作(賦值與刪除),將會影響原始列表。如果說純占位符可以實現(xiàn)列表的拼接,那么,非純占位符可以實現(xiàn)列表的替換。

li = [1, 2, 3, 4]

# 不同位置的替換
li[:3] = [7,8,9] # [7, 8, 9, 4]
li[3:] = [5,6,7] # [7, 8, 9, 5, 6, 7]
li[2:4] = ['a','b'] # [7, 8, 'a', 'b', 6, 7]

# 非等長替換
li[2:4] = [1,2,3,4] # [7, 8, 1, 2, 3, 4, 6, 7]
li[2:6] = ['a'] # [7, 8, 'a', 6, 7]

# 刪除元素
del li[2:3] # [7, 8, 6, 7]

切片占位符可以帶步長,從而實現(xiàn)連續(xù)跨越性的替換或刪除效果。需要注意的是,這種用法只支持等長替換。

li = [1, 2, 3, 4, 5, 6]

li[::2] = ['a','b','c'] # ['a', 2, 'b', 4, 'c', 6]
li[::2] = [0]*3 # [0, 2, 0, 4, 0, 6]
li[::2] = ['w'] # 報錯,attempt to assign sequence of size 1 to extended slice of size 3

del li[::2] # [2, 4, 6]
python主要應(yīng)用領(lǐng)域有哪些

1、云計算,典型應(yīng)用OpenStack。2、WEB前端開發(fā),眾多大型網(wǎng)站均為Python開發(fā)。3.人工智能應(yīng)用,基于大數(shù)據(jù)分析和深度學(xué)習(xí)而發(fā)展出來的人工智能本質(zhì)上已經(jīng)無法離開python。4、系統(tǒng)運維工程項目,自動化運維的標(biāo)配就是python+Django/flask。5、金融理財分析,量化交易,金融分析。6、大數(shù)據(jù)分析。

關(guān)于如何在Python中使用切片就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

網(wǎng)站名稱:如何在Python中使用切片-創(chuàng)新互聯(lián)
分享URL:http://bm7419.com/article48/dsecep.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供手機網(wǎng)站建設(shè)、企業(yè)建站、建站公司品牌網(wǎng)站制作、微信公眾號、網(wǎng)站內(nèi)鏈

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

h5響應(yīng)式網(wǎng)站建設(shè)