假设有以下玩具(来自一个 CSV 文件,其中列名是“键”,我只对放入“数据”的某些行感兴趣):
keys = ['k1', 'k2', 'k3', 'k4']
data = [[1, 2, 3, 4], [5, 6, 7, 8], [9, 10, 11, 12], [13, 14, 15, 16]]
我想得到一个字典,每列都有一个列表,如下所示:
{'k1': [1, 5, 9, 13], 'k2': [2, 6, 10, 14], 'k3': [3, 7, 11, 15], 'k4': [4, 8,
12, 16]}
在我的代码中,我首先使用空列表初始化字典,然后迭代(按键的顺序)以将每个项目附加到列表中。
my_dict = dict.fromkeys(keys, [])
for row in data:
for i, k in zip(row, keys):
my_dict[k].append(i)
但它不起作用。它构建了这个字典:
{'k3': [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16], 'k2': [1, 2, 3,
4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16], 'k1': [1, 2, 3, 4, 5, 6, 7, 8,
9, 10, 11, 12, 13, 14, 15, 16], 'k4': [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12,
13, 14, 15, 16]}
您可以看到所有元素都在所有列表中,而不是每个列表中只有四个元素。如果我在循环中打印 i, k 它会执行正确的项目和键对。所以我想问题是当我在键 k 的列表中添加项目 i 时。
有谁知道为什么所有元素都添加到所有列表中,以及构建我的字典的正确方法是什么?
提前致谢