1

我有一本字典,d其结构如下:

{'k':[5, -2, 6, 7, 2, 4, 8], 'c':[6, 3, 1, 2, 3, 4, 9]}

我想把它写到一个 .csv 中,如下所示:

k, 5, -2, 6, 7, 2, 4, 8
c, 6, 3, 1, 2, -3, 4, 9

我尝试了以下代码:

with open('file.csv', 'w') as f:
    for key in d.keys():
        f.write("%s,%s\n"%(key,d[key]))

不幸的是,这会产生以下结果:

k, [5, -2, 6, 7, 2, 4, 8]
c, [6, 3, 1, 2, -3, 4, 9]

我的解决方案是在之后运行一个trorsed命令,但是必须有一种方法可以先正确地编写它,对吗?

提前致谢!

4

3 回答 3

4
d = {'k':[5, -2, 6, 7, 2, 4, 8], 'c':[6, 3, 1, 2, 3, 4, 9]}

with open('file.csv', 'w') as f:
    for key in d.keys():
        print(key, *d[key], sep=', ', file=f)

打印到文件:

k, 5, -2, 6, 7, 2, 4, 8
c, 6, 3, 1, 2, 3, 4, 9
于 2020-05-22T20:35:36.913 回答
3

我建议首先构建您想要以 CSV 格式写出的列表:

>>> [[k] + v for k, v in d.items()]
[['k', 5, -2, 6, 7, 2, 4, 8], ['c', 6, 3, 1, 2, 3, 4, 9]]

从那里您的原始代码将起作用,但我也建议使用csv.writer而不是滚动您自己的格式:

import csv
with open('file.csv', 'w') as file:
    csv_writer = csv.writer(file)
    for row in [[k] + v for k, v in d.items()]:
        csv_writer.writerow(row)
于 2020-05-22T20:40:51.223 回答
0

您可以使用以下功能join

with open('file.csv', 'w') as f:
    for k, lst in dct.items():
        lst = ','.join(map(str, lst))
        f.write('%s,%s\n' % (k, lst))
于 2020-05-22T22:13:37.097 回答