1.赋值操作,最容易想到的就是赋值操作
- lst1=[1,2,3]
- lst2=lst1
- lst2.append(4)
- print(lst2,lst1)
- #输出结果[1, 2, 3, 4] [1, 2, 3, 4]
可以看到对lst2进行修改,lst1也变了,这是为什么吗呢?
因为python一切传递都是传引用
此时lst2,lst1都将指向同一个列表对象,如下图
此时,在
lst2中所做的修改将反映在lst1 中,反之,在lst1上做的修改。
2.使用copy操作
- lst1=[1,2,3]
- lst2=lst1.copy()
- lst2.append(4)
- print(lst1,lst2)
- #输出结果[1, 2, 3] [1, 2, 3, 4]
此时lst1 和
lst2指向内存中不同的列表对象。由于二者指向内存不同,所以此时在原始列表中所做的修改不会反映在复制的列表中,反之亦然。
3.使用list()
- lst1=[1,2,3]
- lst2=list(lst1)
- lst2.append(4)
- print(lst1,lst2)
- #输出结果[1, 2, 3] [1, 2, 3, 4]
此时lst1 和
lst2指向内存中不同的列表对象。由于二者指向内存不同,所以此时在原始列表中所做的修改不会反映在复制的列表中,反之亦然。
4.使用索引,切片
- lst1=[1,2,3]
- lst2=lst1[:]
- lst2.append(4)
- print(lst1,lst2)
- #输出结果[1, 2, 3] [1, 2, 3, 4]
如果我们使用
lst1[:],它将从头到尾对lst1进行切片,并返回列表的副本。此时在原始列表中所做的修改不会反映在复制的列表中,反之亦然。
5.列表生成式
- lst1=[1,2,3]
- lst2=[i for i in lst1]
- lst2.append(4)
- print(lst1,lst2)
- #输出结果[1, 2, 3] [1, 2, 3, 4]
此时在原始列表中所做的修改不会反映在复制的列表中,反之亦然。
总结
- 使用赋值操作,此时两个列表将指向同一个列表对象
- 使用索引,列表构造函数,列表生成式,copy()等方式时,两个列表将指向不同的列表对象。