列表去重中的copy问题
发布时间:2020-11-06

  列表去重中的copy问题有多少的小伙伴知道或者了解呢?不清楚的小伙伴也不要着急,本篇文章好程序员Python培训小编就给读者们分先一下列表去重中的copy问题,希望对读者们有所帮助。

Python

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

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

  想要了解多关于Python开发方面内容的小伙伴,请关注好程序员Python培训官网、微信公众号等平台

上一篇:
下一篇:
官方客服QQ:
997964424
北京 |深圳|杭州|郑州|上海
微信公众号
Copyright 2007-2019 北京千锋互联科技有限公司.All Right京ICP备12003911号-5 京公安网11010802011455号