zoukankan      html  css  js  c++  java
  • python-深浅copy-18


    # 赋值运算
    l1 = [1,2,3]
    l2 = l1
    l1.append('a')
    print(l1,l2) # [1, 2, 3, 'a'] [1, 2, 3, 'a']

    #copy
    l1 = [1,2,3]
    l2 = l1.copy()
    print(l1,l2) # [1, 2, 3] [1, 2, 3]
    print(id(l1),id(l2)) # 36772744 36771976
    l2.append('a')
    print(l1,l2) # [1, 2, 3] [1, 2, 3, 'a']

    l1 = [1,2,[4,5,6],3]
    l2 = l1.copy()

    print(l1,id(l1)) # [1, 2, [4, 5, 6], 3] 36773832
    print(l2,id(l2)) # [1, 2, [4, 5, 6], 3] 36772744
    l1.append('a')
    print(l1,l2) # [1, 2, [4, 5, 6], 3, 'a'] [1, 2, [4, 5, 6], 3]
    l1[2].append('a')
    print(l1,l2) # [1, 2, [4, 5, 6, 'a'], 3, 'a'] [1, 2, [4, 5, 6, 'a'], 3]
    print(id(l1[2])) # 30302792
    print(id(l2[2])) # 30302792

    import copy
    l1 = [1,2,[4,5,6],3]
    l2 = copy.deepcopy(l1)
    print(l1,id(l1)) # [1, 2, [4, 5, 6], 3] 37541960
    print(l2,id(l2)) # [1, 2, [4, 5, 6], 3] 36773832
    l1[2].append('a')
    print(l1,l2) # [1, 2, [4, 5, 6, 'a'], 3] [1, 2, [4, 5, 6], 3]

    '''
    浅拷贝,只拷贝了列表的第一层,所以第一层的id会不同,但是从第二层甚至更深的层次,id就都是一样的了,
    id(var)函数可以查看内存地址,因此copy()列表第一层是各自独立的,但是从第二层开始就开始相关联。
    真正要实现深度拷贝,必须要用copy.deepcopy()。
    总结:浅拷贝,即只有第一层是各自独立的。
    深拷贝,所有层都是相互独立的。
    '''

    l1 = [1,[1],2,3,4]
    l2 = l1[:]
    l1[1].append('a')



    #l2 的结果是什么?

    print(l1,id(l1)) # [1, [1, 'a'], 2, 3, 4] 30302792
    print(l2,id(l2)) # [1, [1, 'a'], 2, 3, 4] 37541960
    print(l1[1] is l2[1]) # True

    li = ['alex','taibai','wusir','egon']
    for i in li:
    print(li.index(i),i)

    for index,i in enumerate(li,1):
    print(index,i)


    '''
    enumerate()说明
    enumerate()是python的内置函数
    enumerate在字典上是枚举、列举的意思
    对于一个可迭代的(iterable)/可遍历的对象(如列表、字符串),enumerate将其组成一个索引序列,利用它可以同时获得索引和值
    enumerate多用于在for循环中得到计数
    例如对于一个seq,得到:
    '''

    # (0, seq[0]), (1, seq[1]), (2, seq[2])

    # enumerate()返回的是一个enumerate对象,例如:

    # enumerate()使用
    # 如果对一个列表,既要遍历索引又要遍历元素时,首先可以这样写:
    list1 = ["这", "是", "一个", "测试"]
    for i in range (len(list1)):
    print(i ,list1[i])

    # 上述方法有些累赘,利用enumerate()会更加直接和优美:
    list1 = ["这", "是", "一个", "测试"]
    for index, item in enumerate(list1):
    print(index, item)

    # enumerate还可以接收第二个参数,用于指定索引起始值,如:
    list1 = ["这", "是", "一个", "测试"]
    for index, item in enumerate(list1, 1):
    print(index, item)

    #如果要统计文件的行数,可以这样写:

    # count = len(open(filepath, 'r').readlines())

    #这种方法简单,但是可能比较慢,当文件比较大时甚至不能工作。

    #可以利用enumerate():

    # count = 0
    # for index, line in enumerate(open(filepath,'r')):
    # count += 1


    扩展:python3【基础】-赋值与深浅拷贝

    https://blog.csdn.net/weixin_38246633/article/details/84310770

  • 相关阅读:
    apply call bind方法的区别和含义
    html头部meta标签
    语义化标签
    “文件名和url路径名”命名要点以及大小写问题
    BMP GIF PNG JPG等图片格式的区别和适用情况
    前端页面的性能优化
    js阻止默认事件,如a标签跳转和事件冒泡
    散列碰撞问题的解决——开链法(拉链法)
    substring()方法
    对学生成绩进行散列
  • 原文地址:https://www.cnblogs.com/LXL616/p/10643244.html
Copyright © 2011-2022 走看看