今天做项目的时候,需要用一个多层列表来进行数据处理。
为了偷懒,定义了一个简易的制作多层列表的函数:
def list_produce(content,number):
y = []
for i in range(number):
y.append(content)
return y
上述函数可以制作一个包含number个content的列表,如:
l = list_produce([],5)
print(l)
output:
[[], [], [], [], []]
但是,在给大列表里的小列表添加值的时候,却出了问题。
l = list_produce([],5)
for i in range(5):
l[i].append(i)
print(l)
output:
[[0, 1, 2, 3, 4], [0, 1, 2, 3, 4], [0, 1, 2, 3, 4], [0, 1, 2, 3, 4], [0, 1, 2, 3, 4]]
发现大列表中的小列表是同步操作的,对其中任何一个小列表做出操作,其余列表都会重复相应操作。
原因是在函数定义时,把content的值赋给了列表中的number个对象,但是这number个对象指向的地址仍然是同一个content的地址。
l = list_produce([],5)
for i in range(5):
print(id(l[i]))
output:
1242608365448
1242608365448
1242608365448
1242608365448
1242608365448
因此,需要重新定义函数:
def list_produce(content,number):
y = []
for i in range(number):
y.append(content.copy())
return y
把content的副本加入列表,这样就可以消除同步操作。
l = list_produce([],5)
for i in range(5):
l[i].append(i)
print(l)
output:
[[0], [1], [2], [3], [4]]
大家在编写代码时,一定要记得关注变量的存储位置,不然很可能会出现问题。