Python 列表拷贝很容易搞错,这里做一下简单的总结。通常我们只是想根据现有的列表来创建一个全新的列表,而一说到列表拷贝,可能会下意识的想到直接用“=”,那么我们通过示例来看看实际的结果。
看一个示例:
listA=["aaa","bbb","ccc"]
listB=listA
print("listA = ",listA)
print("listB = ",listB)
输出如下:
listA = ['aaa', 'bbb', 'ccc']
listB = ['aaa', 'bbb', 'ccc']
这看起来好像拷贝成功了,那么再做个试验:
listA=["aaa","bbb","ccc"]
listB=listA
print("listA = ",listA)
print("listB = ",listB)
listA.append("ddd")
listB.append("eee")
print("after listA = ",listA)
print("after listB = ",listB)
输出如下:
listA = ['aaa', 'bbb', 'ccc']
listB = ['aaa', 'bbb', 'ccc']
after listA = ['aaa', 'bbb', 'ccc', 'ddd', 'eee']
after listB = ['aaa', 'bbb', 'ccc', 'ddd', 'eee']
这时候发现输出结果和我们预期的并不一样,其原因是,我们直接将 listA 赋值给 listB,实际上只是将新变量 listB 关联到了 listA,并没有将 listA 的副本存储到 listB,所以当我们分别给 listA 和 listB 插入数据的时候,都是插入到 listA 中,而 listB 可以理解为 listA 的一个“别名”。所以如果想要做 Python 的列表拷贝,千万不要用直接赋值的方式,这样并不能得到我们想要的结果。
Python 提供了一种新的方式来进行列表拷贝,那就是“切片”。
示例如下:
listB=listA[:]
再来看看上面的示例:
listA=["aaa","bbb","ccc"]
listB=listA[:]
print("listA = ",listA)
print("listB = ",listB)
listA.append("ddd")
listB.append("eee")
print("after listA = ",listA)
print("after listB = ",listB)
输出结果:
listA = ['aaa', 'bbb', 'ccc']
listB = ['aaa', 'bbb', 'ccc']
after listA = ['aaa', 'bbb', 'ccc', 'ddd']
after listB = ['aaa', 'bbb', 'ccc', 'eee']
OK,这才是我们真正想要的结果,listB 完全是全新的列表。
以上方式其实类似于 C++的深拷贝和浅拷贝,在使用过程中要相当注意,很容易出错。