列表去重中的copy问题

一般而言,列表去重无非那几种方法。

第一种,利用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值不一样),所以下面的列表删除元素后元素的变动不影响拷贝后的列表值。

 

最后告诉你的是,

零基础学习Python肯定难,Python的专业程度本身就不简单,学习这事本来就是一件非常煎熬的事情,人都不愿意学习,可是没办法,为了生存掌握一个技能,你必须学。自己一个人努力拼搏可能最终短期见不到效果容易重复走弯路,而与千人Py学习者一起努力,相当于一千个人在帮你。欢迎在QQ上加入我们学习聚集群:816572891。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值