有一个字典名称,最初,它的值为
{'Натариус': 0, 'Traiding': 3, 'Бар Шелк': 17, и т д}
然后我通过excel文件运行一个循环,将它添加到列表中并想要更新列表
for v in name:
for row in range(name[v], row_number):
if (str(sheet.row(row)[1]).find("empty") < 0):
l.append(str(sheet.row(row)[1]).replace("text:", "").replace("'", ""))
#print(str(sheet.row(row)[1]).replace("text:", "").replace("'", ""))
else:
name.update({v: l})
l.clear()
break
但是由于某种原因,它不断地通过原始密钥更新记录。这是一个工作示例。第一步
l = ['244 66 14', '244 66 15']
name = {'Натариус': ['244 66 14', '244 66 15'], 'Traiding': 3, 'Бар Шелк': 17, и т д}
超级名单已更新。但是当它通过第二次循环时,则剩下以下值\u200b\u200bare
l = ['244 66 00', '244 66 01', '244 66 02', '244 66 03', '244 66 04', '244 66 05', '244 66 06', '244 66 48', '244 66 47', '244 67 25', '244 67 15', '244 66 13', '244 66 87'] #все верно
name = {'Натариус': ['244 66 00', '244 66 01', '244 66 02', '244 66 03', '244 66 04', '244 66 05', '244 66 06', '244 66 48', '244 66 47', '244 67 25', '244 67 15', '244 66 13', '244 66 87'], 'Traiding': ['244 66 00', '244 66 01', '244 66 02', '244 66 03', '244 66 04', '244 66 05', '244 66 06', '244 66 48', '244 66 47', '244 67 25', '244 67 15', '244 66 13', '244 66 87'], 'Бар Шелк': 17, и т д} # не верно
它在第一个密钥和第二个密钥上进行了更新。Itd 在列表中,它会不断更新所有键,而不是选定的键。
错误在哪里?
您添加的不是列表的副本,而是列表的链接。为了避免这种情况,你可以取一个完整的切片,因为切片总是返回一个新对象: