Python中remove漏刪和索引越界問題的解決
list.remove方法在刪除元素的時(shí)候往往會(huì)出現(xiàn)漏刪或者索引越界的情況示例如下:
漏刪:
lst=[9,25,12,36]for i in lst:if i>10:lst.remove(i)print(lst)
>>>[9, 12]
那么為什么12被漏刪了呢?其實(shí)原理很簡(jiǎn)單,如圖:
列表從下標(biāo)為0開始遍歷,遍歷到25時(shí),將25刪除,返回一個(gè)新的列表:
注意,原來(lái)的25對(duì)應(yīng)的下標(biāo)是1,所以系統(tǒng)會(huì)從下標(biāo)為2的地方開始遍歷,但是在新列表中,下標(biāo)為2的地方變成了36,所以12就被跳過了。
解決方法:
只需要判斷如果列表中刪除元素,就要重新從0開始遍歷列表。
lst=[9,25,12,36]while True:for i in lst:if i>10:lst.remove(i)#如果刪除了元素,退出此次遍歷,開始遍歷新列表breakelse:breakprint(lst)
>>>[9]
索引越界:
當(dāng)我們用下標(biāo)遍歷列表時(shí),會(huì)出現(xiàn)索引越界的情況,如圖:
lst=[9,25,12,36]for i in range(len(lst)):# print(i)if lst[i]>10:lst.remove(lst[i])print(lst)
IndexError: list index out of range
原理都是一樣的,這里 i 的取值為 0 1 2 3 ,當(dāng)刪除一個(gè)元素之后,新列表的長(zhǎng)度減少,索引變?yōu)?0 1 2 ,但是 i 還是根據(jù)原來(lái)列表的索引取值,所以當(dāng) i 取到 3 的時(shí)候,新列表沒有該元素,索引越界。
解決方法一:
lst=[25,9,12,36]j=0for i in range(len(lst)):if lst[j]>10:# 下面以j取0為例:# j =0 時(shí)對(duì)應(yīng)元素25被刪除,# continue的做法的意思是判斷新列表的j元素即0元素是否符合條件lst.remove(lst[j])continue# 如果新列表的j = 0 處不符合條件,j+1,然后再判斷下一個(gè)元素。j+=1print(lst)
解決方法二(推薦):
如果讓索引倒序遍歷列表就不會(huì)出現(xiàn)越界的問題了。這樣就算新列表的長(zhǎng)度減小了,那么i 的取值是倒著取的,列表缺少一個(gè)元素對(duì) i 的取值無(wú)影響。例如 i 為3 的元素被刪除了,新列表最高索引為2 而此時(shí) i的下一個(gè)取值正好是 2 ,沒有影響。
lst=[9,25,12,36]for i in range(len(lst)-1,-1,-1):# i : 3 2 1 0if lst[i]>10:lst.remove(lst[i])print(lst)
到此這篇關(guān)于Python中remove漏刪和索引越界問題的解決的文章就介紹到這了,更多相關(guān)Python remove漏刪和索引越界內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. PHP循環(huán)與分支知識(shí)點(diǎn)梳理2. ASP基礎(chǔ)入門第三篇(ASP腳本基礎(chǔ))3. 解析原生JS getComputedStyle4. ASP實(shí)現(xiàn)加法驗(yàn)證碼5. 無(wú)線標(biāo)記語(yǔ)言(WML)基礎(chǔ)之WMLScript 基礎(chǔ)第1/2頁(yè)6. ASP刪除img標(biāo)簽的style屬性只保留src的正則函數(shù)7. 讀大數(shù)據(jù)量的XML文件的讀取問題8. css代碼優(yōu)化的12個(gè)技巧9. 利用CSS3新特性創(chuàng)建透明邊框三角10. 前端從瀏覽器的渲染到性能優(yōu)化
