a = [1, 2, 3]
b = a
b[0] = 0
print(b) # 输出结果:[0, 2, 3]
print(a) # 输出结果:[0, 2, 3]
这并不我想要的结果,我只希望拷贝一个a的副本b,当我改变b时不希望a变化。
究其原因,在 Python 中,将一个列表赋值给另一个变量,如 b = a,你并没有创建一个新的列表副本,而是创建了一个指向同一列表的新引用。因此,当修改 b 时,由于 a 和 b 指向同一个列表,a 也会发生改变。
如果你想要修改 b 而保持 a 不变,需要创建 a 的一个副本。在 Python 中,可以通过多种方式来实现副本的创建:
1、使用copy()
a = [1, 2, 3]
b = a.copy()
b[0] = 0
print(b) # 输出结果:[0, 2, 3]
print(a) # 输出结果:[1, 2, 3]
2、使用list()
a = [1, 2, 3]
b = list(a)
b[0] = 0
print(b) # 输出结果:[0, 2, 3]
print(a) # 输出结果:[1, 2, 3]
3 、使用切片
a = [1, 2, 3]
b = []
b[:] = a
b[0] = 0
print(b) # 输出结果:[0, 2, 3]
print(a) # 输出结果:[1, 2, 3]
4、以上都是浅拷贝。如果列表 a 包含了其他可变数据类型,比如列表,以上方法也实现不了副本拷贝的功能。
以下代码验证:
a = [[1, 2], 3]
b = a.copy()
b[0][0] = 0
print(b) # 输出结果:[[0, 2], 3]
print(a) # 输出结果:[[0, 2], 3]b[:] = a
b[0][0] = 0
print(b) # 输出结果:[[0, 2], 3]
print(a) # 输出结果:[[0, 2], 3]b = list(a)
b[0][0] = 0
print(b) # 输出结果:[[0, 2], 3]
print(a) # 输出结果:[[0, 2], 3]
所以使用深拷贝来确保这些内部元素也被拷贝。深拷贝可以通过 copy 模块的 deepcopy() 函数实现:
import copya = [[1, 2], 3]
b = copy.deepcopy(a)
b[0][0] = 0
print(b) # 输出结果:[[0, 2], 3]
print(a) # 输出结果:[[1, 2], 3]