使用 Python 3.3.0,我从 csv 文件(标题:)创建了一个“字典” ID;Col1;Col2;Col3;Col4;Col5
:
ID;Col1;Col2;Col3;Col4;Col5
15345;1;1;nnngngn;vhrhtnz;latest
12345;12;8;gnrghrtthr;tznhltrnhklr;latest
90834;3;4;something;nonsens;latest
12345;34;235;dontcare;muhaha;oldone
带代码
file = "test.csv"
csv_file = csv.DictReader(open(file, 'r'), delimiter=';', quotechar='"')
我想将 ID = 12345 的行复制到新字典中,而不是复制到文件中。我真的需要复制到字典中,而不是列表中,因为我希望能够直接处理列名。我这样做了
cewl = {}
for row in csv_file:
if row['ID'] == '12345':
cewl.update(row)
print(cewl)
输出是:
{'ID': '12345', 'Col1': '34', 'Col2': '235', 'Col3': 'dontcare', 'Col4': 'muhaha', 'Col5': 'oldone'}
我的问题: 只有 ID=12345 的第二行被复制,第一行被省略,我不知道为什么。
如果我通过复制到一个新列表来尝试这个(仅用于测试目的),一切正常:
cewl = []
for row in csv_file1:
if row['ID'] == '12345':
cewl.append(row)
print(cewl)
输出是:
[{'Col3': 'gnrghrtthr', 'Col2': '8', 'Col1': '12', 'Col5': 'latest', 'Col4': 'tznhltrnhklr', 'ID': '12345'},
{'Col3': 'dontcare', 'Col2': '235', 'Col1': '34', 'Col5': 'oldone', 'Col4': 'muhaha', 'ID': '12345'}]
我不知道为什么通过复制到新字典中这不起作用……似乎没有像 .add 或 .append 这样的方法用于 dictreader。
如何将我的数据复制到新字典中而不会丢失任何行?