使用del命令刪除列表中的指定位置上的元素。
>>>a_list=[3,5,7,9,11]
>>>dela_list[1]
>>>a_list
[3,7,9,11]
使用列表的pop()方法刪除并返回指定位置(默認為最后一個)上的元素,如果給定的索引超出了列表的范圍則拋出異常。
>>>a_list=list((3,5,7,9,11))
>>>a_list.pop()
11
>>>a_list
[3,5,7,9]
>>>a_list.pop(1)
5
>>>a_list
[3,7,9]
使用列表對象的remove()方法刪除首次出現的指定元素,如果列表中不存在要刪除的元素,則拋出異常。
>>>a_list=[3,5,7,9,7,11]
>>>a_list.remove(7)
>>>a_list
[3,5,9,7,11]
代碼編寫好后必須要經過反復測試,不能滿足于幾次測試結果正確。例如,下面的代碼成功地刪除了列表中的重復元素,執行結果是完全正確的。
>>>x=[1,2,1,2,1,2,1,2,1]
>>>foriinx:
ifi==1:
x.remove(i)
>>>x
[2,2,2,2]
然而,上面這段代碼的邏輯是錯誤的。同樣的代碼,僅僅是所處理的數據發生了一點變化,然而當循環結束后卻發現并沒有把所有的“1”都刪除,只是刪除了一部分。
>>>x=[1,2,1,2,1,1,1]
>>>foriinx:
ifi==1:
x.remove(i)
>>>x
[2,2,1]
兩組數據的本質區別在于,第一組數據中沒有連續的“1”,而第二組數據中存在連續的“1”。出現這個問題的原因是列表的自動內存管理功能。
在刪除列表元素時,Python會自動對列表內存進行收縮并移動列表元素以保證所有元素之間沒有空隙,增加列表元素時也會自動擴展內存并對元素進行移動以保證元素之間沒有空隙。每當插入或刪除一個元素之后,該元素位置后面所有元素的索引就都改變了。
正確的代碼:
>>>x=[1,2,1,2,1,1,1]
>>>foriinx[::]:#切片
ifi==1:
x.remove(i)
或者:
>>>x=[1,2,1,2,1,1,1]
>>>foriinrange(len(x)-1,-1,-1):#從后往前刪
ifx[i]==1:
delx[i]
以上內容為大家介紹了python列表元素的刪除,希望對大家有所幫助,如果想要了解更多Python相關知識,請關注IT培訓機構:千鋒教育。