我想了解在将新数据添加到字典时,python 中的内存分配是如何工作的。在下面的代码中,我一直在等待每个新添加的数据最后都堆叠起来,但它并没有发生。
repetitions = {}
for item in new_deltas:
list_aux = []
if float(item[1]) <= 30:
if float(item[0]) in repetitions:
aux = repetitions[float(item[0])]
aux.append(item[1])
repetitions[float(item[0])] = aux
else:
list_aux.append(item[1])
repetitions[float(item[0])] = list_aux
print(repetitions)
我得到的结果如下。因此,我想了解为什么新的附加数据没有添加到堆栈的末尾,而是添加到堆栈的中间。
我的输入数据是:
new_deltas = [[1.452, 3.292182683944702], [1.449, 4.7438647747039795], [1.494, 6.192960977554321], [1.429, 7.686920166015625]]
打印行输出:
{1.452: [3.292182683944702]}
{1.452: [3.292182683944702], 1.449: [4.7438647747039795]}
{1.452: [3.292182683944702], 1.494: [6.192960977554321], 1.449: [4.7438647747039795]}
{1.429: [7.686920166015625], 1.452: [3.292182683944702], 1.494: [6.192960977554321], 1.449: [4.7438647747039795]}
POPMUISE
HUX布斯
相关分类