2020-11-06
Python培訓
列表去重中的copy問題有多少的小伙伴知道或者了解呢?不清楚的小伙伴也不要著急,本篇文章好程序員Python培訓小編就給讀者們分先一下列表去重中的copy問題,希望對讀者們有所幫助。
一般而言,列表去重無非那幾種方法:
diyi種,利用set()沒有重復值的特性去重,簡單,但是無序。
第二種,判斷循環的元素是否在新列表中以此來去掉重復值,可以保持原來的順序。
第三種,循環遍歷,判斷當前元素的個數是否大于1,然后在刪除當前元素(需注意刪除元素后列表的變化),無序。
今天主要說的就是第三種方法了。
示例代碼:
list1 = [1,3,4,1,2,2,2,2,1,2]
for item in list1:
print(item)
# 統計元素的個數
count = list1.count(item)
# 如果個數大于1,就刪一個
if count > 1:
list1.remove(item)
print(list1)
#運行結果
1
[3, 4, 1, 2, 2, 2, 2, 1, 2]
4
[3, 4, 1, 2, 2, 2, 2, 1, 2]
1
[3, 4, 2, 2, 2, 2, 1, 2]
2
[3, 4, 2, 2, 2, 1, 2]
2
[3, 4, 2, 2, 1, 2]
2
[3, 4, 2, 1, 2]
Process finished with exit code 0
看最后結果,就知道這次去重失敗了,是因為沒有注意元素位置移動的問題。那請仔細看下面的代碼有什么不同:
list1 = [1,3,4,1,2,2,2,2,1,2]
for item in list1.copy():
print(item)
count = list1.count(item)
if count > 1:
list1.remove(item)
print(list1)
#運行結果
1
[3, 4, 1, 2, 2, 2, 2, 1, 2]
3
[3, 4, 1, 2, 2, 2, 2, 1, 2]
4
[3, 4, 1, 2, 2, 2, 2, 1, 2]
1
[3, 4, 2, 2, 2, 2, 1, 2]
2
[3, 4, 2, 2, 2, 1, 2]
2
[3, 4, 2, 2, 1, 2]
2
[3, 4, 2, 1, 2]
2
[3, 4, 1, 2]
1
[3, 4, 1, 2]
2
[3, 4, 1, 2]
Process finished with exit code 0
只是加了一個copy()方法,就避免了元素位置因為刪除而移動的問題。copy()方法是淺拷貝,它將列表的值都拷貝了出來,且生成了一個新的空間存儲值(copy()方法后新列表的id值和原來的列表id值不一樣),所以下面的列表刪除元素后元素的變動不影響拷貝后的列表值。
開班時間:2021-04-12(深圳)
開班盛況開班時間:2021-05-17(北京)
開班盛況開班時間:2021-03-22(杭州)
開班盛況開班時間:2021-04-26(北京)
開班盛況開班時間:2021-05-10(北京)
開班盛況開班時間:2021-02-22(北京)
開班盛況開班時間:2021-07-12(北京)
預約報名開班時間:2020-09-21(上海)
開班盛況開班時間:2021-07-12(北京)
預約報名開班時間:2019-07-22(北京)
開班盛況Copyright 2011-2023 北京千鋒互聯科技有限公司 .All Right 京ICP備12003911號-5 京公網安備 11010802035720號