美文网首页
列表去重中的copy问题

列表去重中的copy问题

作者: 隐墨留白 | 来源:发表于2019-01-04 17:52 被阅读0次

    一般而言,列表去重无非那几种方法。
    第一种,利用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值不一样),所以下面的列表删除元素后元素的变动不影响拷贝后的列表值。详情请看

    相关文章

      网友评论

          本文标题:列表去重中的copy问题

          本文链接:https://www.haomeiwen.com/subject/smskrqtx.html