zoukankan      html  css  js  c++  java
  • 彻底测试全部拷贝list相关操作的区别python

    1.用浅拷贝后修改数字,可以起到与原数据分离的效果
    import copy
    origin = [1, 2, [3, 4]]
    #origin 里边有三个元素:12,[3, 4]
    
    cop1=origin.copy()
    #cop1 和 cop2 看上去相同,但已不再是同一个object
    cop1[1]='6765765'
    print (cop1)
    print (origin)
    
    
    
    #把origin内的子list [3, 4] 改掉了一个元素,观察 cop1 和 cop2
    View Code

    2.用浅拷贝后修改子list,或者修改子list里面任何一个数据都不可以起到与原数据分离的效果

    import copy
    origin = [1, 2, [3, 4]]
    #origin 里边有三个元素:12,[3, 4]
    
    cop1=origin.copy()
    #cop1 和 cop2 看上去相同,但已不再是同一个object
    cop1[2][0]='6765765'
    print (cop1)
    print (origin)
    
    
    
    #把origin内的子list [3, 4] 改掉了一个元素,观察 cop1 和 cop2
    View Code

    3.用等号后修改数字,不可以起到与原数据分离的效果

    import copy
    origin = [1, 2, [3, 4]]
    #origin 里边有三个元素:12,[3, 4]
    
    cop1=origin
    #cop1 和 cop2 看上去相同,但已不再是同一个object
    cop1[1]='6765765'
    print (cop1)
    print (origin)
    
    
    
    #把origin内的子list [3, 4] 改掉了一个元素,观察 cop1 和 cop2
    View Code

    4.用等号后修改子list,或者修改子list里面任何一个数据都不可以起到与原数据分离的效果

    import copy
    origin = [1, 2, [3, 4]]
    #origin 里边有三个元素:12,[3, 4]
    
    cop1=origin
    #cop1 和 cop2 看上去相同,但已不再是同一个object
    cop1[2][0]='6765765'
    print (cop1)
    print (origin)
    
    
    
    #把origin内的子list [3, 4] 改掉了一个元素,观察 cop1 和 cop2
    View Code

    5.用deepcopy,随便修改,都可以起到与原数据分离的效果

    import copy
    origin = [1, 2, [3, 4]]
    #origin 里边有三个元素:12,[3, 4]
    
    cop1=copy.deepcopy(origin)
    #cop1 和 cop2 看上去相同,但已不再是同一个object
    cop1[1]='6765765'
    print (cop1)
    print (origin)
    
    
    
    #把origin内的子list [3, 4] 改掉了一个元素,观察 cop1 和 cop2
    View Code

     6.继续写一个list的乘法.如果

    a=[0]*99 ,那么a里面数据都可以随意修改

    a=[[0]]*99,那么a里面任何index的数据都永远相等,无论怎么修改.

    7.python for else的坑

    这里面else表示的是如果for的循环你使用break跳出的那么else不执行,否则必然执行else.如果你不写break,那么else语句就必然执行.

  • 相关阅读:
    Linux openkvm disk expansion
    FineReport 交叉报表
    Linux crontab 查看所有用户的crontab任务
    Nginx 配置操作注意事项
    MYSQL Packet for query is too large (12054240 > 4194304). You can change this value on the server by setting the max_allowed_packet' variable.
    Navicat Premium 12 mysql show error: connection is being used
    SpringMVC RequestLoggingFilter log to file
    JEECG MiniDao优劣
    网站安全统一监测平台(WebPecker)
    Spring @Transactional at interface
  • 原文地址:https://www.cnblogs.com/zhangbo2008/p/8594403.html
Copyright © 2011-2022 走看看