python的列表list能夠用for循環進行遍歷,實際開發中發現一個問題,就是遍歷的時候刪除會出錯,例如
l = [1,2,3,4]
for i in l:
if i != 4:
l.remove(i)
print l
這幾句話原本意圖是想清空列表l,只留元素4,可是實際跑起來並非那個結果。再看下面,利用index來遍歷刪除列表l
l = [1, 2, 3, 4]
for i in range(len(l)):
if l[i] == 4:
del l[i]
print l
這樣沒問題,能夠遍歷刪除,可是列表l若是變爲 l = [1,2,3,4,5]
若是仍是按照上面的方法,設想一下,range開始的範圍是0-4,中間遍歷的時候刪除了一個元素4,這個時候列表變成了= [1,2,3,5],這時候就會報錯了,提示下標超出了數組的表示,緣由就是上面說的遍歷的時候刪除了元素
因此python的list在遍歷的時候刪除元素必定要當心
可使用filter過濾返回新的list
l = [1,2,3,4]
l = filter(lambda x:x !=4,l)
print l
這樣能夠安全刪除l中值爲4的元素了,filter要求兩個參數,第一個是規則函數,第二個參數要求輸入序列,而lambda這個函數的做用就是產生一個函數,是一種緊湊小函數的寫法,通常簡單的函數能夠這麼些
或者能夠這樣
l = [1,2,3,4]
l = [ i for i in l if i !=4]//一樣產生一個新序列,復值給l
print l
或者乾脆創建新的list存放要刪除的元素
l = [1,2,3,4]
dellist = []
for i in l:
if i == 4:
dellist.append(i)
for i in dellist:
l.remove(i)
這樣也能安全刪除元素
因此要遍歷的時候刪除元素必定要當心,特別是有些操做並不報錯,但卻沒有達到預期的效果
上面說到產生新序列,賦值等等,用python的id()這個內置函數來看對象的id,能夠理解爲內存中的地址,因此有個簡要說明
若是
l = [1,2,3,4]
ll = l
l.remove(1)
print l//確定是[2,3,4]
print ll//這裏會是什麼?
若是用id函數查看的話就發現
print id(l),id(ll)
打印出相同的號碼,說明他們實際上是一個值,也就是說上面的print ll將和l打印的同樣,因此python有這種性質,用的時候注意一下就好了