今天在使用Python的时候遇到了一个非常基础的问题,把字典添加到列表里,但是结果列表的值全都一样。
问题代码:
test = []
data = {}
for i in range(1,3):
data['id'] = i
data['centent'] = "这是第%d个数字"%i
test.append(data)
# print(test)
for i in test:
print(i)
结果:
{'id': 9, 'centent': '这是第9个数字'}
{'id': 9, 'centent': '这是第9个数字'}
{'id': 9, 'centent': '这是第9个数字'}
{'id': 9, 'centent': '这是第9个数字'}
{'id': 9, 'centent': '这是第9个数字'}
{'id': 9, 'centent': '这是第9个数字'}
{'id': 9, 'centent': '这是第9个数字'}
{'id': 9, 'centent': '这是第9个数字'}
{'id': 9, 'centent': '这是第9个数字'}
和预想的不一样,于是调试了一下代码:
第一次循环时列表和字典都正常,接着下一次循环:
到这一步问题就出来了,当字典里的值变化时,列表里的值也相应地发生了变化,所以导致结果永远是前一个被后一个覆盖掉。
按照预期的结果应该将字典设置为局部变量,这时候每循环一次,都是一个新的字典,不会影响后续的循环
test = []
for i in range(1,10):
data = {}
data['id'] = i
data['centent'] = "这是第%d个数字"%i
test.append(data)
# print(test)
for i in test:
print(i)
结果:
{'id': 1, 'centent': '这是第1个数字'}
{'id': 2, 'centent': '这是第2个数字'}
{'id': 3, 'centent': '这是第3个数字'}
{'id': 4, 'centent': '这是第4个数字'}
{'id': 5, 'centent': '这是第5个数字'}
{'id': 6, 'centent': '这是第6个数字'}
{'id': 7, 'centent': '这是第7个数字'}
{'id': 8, 'centent': '这是第8个数字'}
{'id': 9, 'centent': '这是第9个数字'}