python列表中remove()函數(shù)的使用方法詳解
1. 基本使用
remove() 函數(shù)可以刪除列表中的指定元素
語法
list.remove( element )
參數(shù)
- element:任意數(shù)據(jù)類型(數(shù)字、字符串、列表等)
2. 刪除普通類型元素
刪除一個列表中「存在」的數(shù)字或字符串
list1 = ['zhangsan', 'lisi', 1, 2]
list1.remove(1) # 刪除數(shù)字
print(list1)
list1.remove('zhangsan') # 刪除字符串
print(list1)
輸出:
['zhangsan', 'lisi', 2]
['lisi', 2]
如果列表中「不存在」想要刪除的元素,則會報錯
list1 = [1, 2, 3] list1.remove(4)
輸出:
Traceback (most recent call last):
? File "E:/data/PrCharm/test1/55.py", line 2, in <module>
? ? list1.remove(4)
ValueError: list.remove(x): x not in list
# 值錯誤: 需要刪除的值不在列表中
3. 刪除對象類型元素
刪除一個列表中「存在」的對象元素(列表、元祖等)
list1 = [1, 2, [3, 4], (5, 6)] a = [3, 4] b = (5, 6) list1.remove(a) # 刪除列表類型 print(list1) list1.remove(b) # 刪除元祖類型 print(list1)
輸出:
[1, 2, (5, 6)]
[1, 2]
需要注意的是:remove刪除對象類型的前提是,列表中的某個「元素」是對象類型,以下這種方式會報錯
list1 = [1, 2, 3] list1.remove([1,2])
輸出:
Traceback (most recent call last):
? File "E:/data/PrCharm/test1/55.py", line 2, in <module>
? ? list1.remove([1,2])
ValueError: list.remove(x): x not in list
# 值錯誤: 需要刪除的值不在列表中
4. 一次只刪一個元素
? ? ? ? 上面的案例中,列表 [1, 2] 看似在列表 [1, 2, 3] 中存在,實際上, remove() 函數(shù)判斷元素是否在列表中存在的標準是:匹配列表中的「單個元素」,而不是整個列表。
? ? ? ? ?remove() 函數(shù)會遍歷列表中的每一個元素,查看是否有元素與之匹配,匹配到相同的元素才會執(zhí)行刪除,這也就意味著 remove() 函數(shù)一次只能刪除一個元素。
? ? ? ?自己刪自己也不行,因為自己并不在自己的元素中
list1 = [1, 2, 3, 4, 5]
print('我自己在我自己里面嗎?', list1 in list1)
list1.remove(list1)
輸出:
Traceback (most recent call last):
? File "E:/data/PrCharm/test1/55.py", line 3, in <module>
? ? list1.remove(list1)
ValueError: list.remove(x): x not in list
我自己在我自己里面嗎? False
5、Python列表的remove方法的注意事項

為何沒有刪除列表中的全部元素?
解釋:
按照執(zhí)行順序,第一個空格被刪除之后,后面的元素會前移(變成['空格','空格','12','23']),指針下一次會指向新列表的第二個元素(即初始狀態(tài)的第三個空格),從而初始狀態(tài)的第二個空格被跳過了,初始第三個空格被刪除,接著后面的元素又再次前移(變成['空格','12','23']),指針指向新列表的第三個元素,即初始狀態(tài)的第5個元素23,然后23被刪除了,因此只剩下['空格','12']
如果想排除初始列表中的部分元素,如何實現(xiàn)?
由上面的情況知道,在遍歷列表的同時對列表執(zhí)行刪除操作,會造成意外的結(jié)果,那么對初始列表進行遍歷,對初始的列表的副本執(zhí)行刪除操作呢?

以上結(jié)果顯示,沒有得到預(yù)期效果。為什么?
問題出在copy=ls這一句,這里僅僅是使得copy與ls指向了同一片內(nèi)存(即淺拷貝,shallow copy),并沒有執(zhí)行【開辟一片新內(nèi)存,并且ls內(nèi)存中的內(nèi)容復(fù)制到新內(nèi)存,然后使copy指向新開辟的內(nèi)存,即深拷貝,deep copy】這一系列操作。因此對copy執(zhí)行的remove操作,和對遍歷ls列表,實質(zhì)上還是都是針對同一片內(nèi)存進行操作,因此結(jié)果上一個例子類似。
若想解決這一問題,有3個辦法法:
(1)
ls=[' ',' ',' ','12','23','abc','aa'] copy=[' ',' ',' ','12','23','abc','aa']
這一辦法對于已知列表的所有元素,且元素數(shù)量較少,結(jié)構(gòu)較簡單時可行,其他情況下不可行。
(2)引入copy模塊的deepcopy方法:

(3)另外準備一個空列表,遍歷初始列表時,將符合條件的元素逐一加入到空列表當中(利用列表的append方法)。
這種方法,思路上與remove方法相反,但執(zhí)行的操作差不多,時間復(fù)雜度也與remove方法差不多,無需引入copy模塊。
另外,對于列表的remove方法,python基礎(chǔ)教程第二版給出的說明是:
remove方法用于移除列表中某個值的第一個匹配項:
>>>x=['to','be','or','not','to','be']
>>>x.remove('be')
>>>x
['to','or','not','to','be']
總結(jié)
到此這篇關(guān)于python列表中remove()函數(shù)使用的文章就介紹到這了,更多相關(guān)python列表remove()函數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python爬蟲實戰(zhàn)之爬取京東商品數(shù)據(jù)并實實現(xiàn)數(shù)據(jù)可視化
今天再帶大家簡單爬一波京東的商品數(shù)據(jù)唄,廢話不多說,文中有非常詳細的代碼示例,需要的朋友可以參考下2021-06-06
python中斷time.sleep一種更優(yōu)雅的方式:event.wait
這篇文章主要介紹了python中斷time.sleep一種更優(yōu)雅的方式:event.wait,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-11-11
python 2.6.6升級到python 2.7.x版本的方法
這篇文章主要介紹了python 2.6.6升級到python 2.7.x版本的方法,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-10-10
如何將anaconda安裝配置的mmdetection環(huán)境離線拷貝到另一臺電腦
這篇文章主要介紹了如何將anaconda安裝配置的mmdetection環(huán)境離線拷貝到另一臺電腦,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-10-10
python進程池實現(xiàn)的多進程文件夾copy器完整示例
這篇文章主要介紹了python進程池實現(xiàn)的多進程文件夾copy器,結(jié)合完整實例形式分析了Python基于多進程與進程池的文件操作相關(guān)實現(xiàn)技巧,需要的朋友可以參考下2019-11-11
python如何實現(xiàn)不可變字典inmutabledict
這篇文章主要介紹了python如何實現(xiàn)不可變字典inmutabledict,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-01-01
使用Pytorch實現(xiàn)Swish激活函數(shù)的示例詳解
激活函數(shù)是人工神經(jīng)網(wǎng)絡(luò)的基本組成部分,他們將非線性引入模型,使其能夠?qū)W習(xí)數(shù)據(jù)中的復(fù)雜關(guān)系,Swish 激活函數(shù)就是此類激活函數(shù)之一,在本文中,我們將深入研究 Swish 激活函數(shù),提供數(shù)學(xué)公式,探索其相對于 ReLU 的優(yōu)勢,并使用 PyTorch 演示其實現(xiàn)2023-11-11

