将列表字典写入CSV文件

4
我希望您能够将字典列表写入CSV文件并进行翻译。我希望键值成为CSV文件的标头,并且与每个键相关联的值在与该键关联的列中。 如果我的字典是:
{'600': [321.4, 123.5, 564.1, 764.1], '300': [12.7, 154.7, 327.5, 894.4], 'Position': [1,2,3,4]}

我尝试使用csv.DictWriter,如下所示:

    import csv
outputFile=open('chan_press_prof.csv','wb')
dictPress={'600': [321.4, 123.5, 564.1, 764.1], '300': [12.7, 154.7, 327.5, 894.4], 'Position': [1,2,3,4]}
fields=['Position','300','600']
writeFile = csv.DictWriter(outputFile, fieldnames=fields)
writeFile.writeheader()
writeFile.writerow(dictPress)
outputFile.close()

但我得到了一堆乱码:

位置,300,600 "[1, 2, 3, 4]","[12.7, 154.7, 327.5, 894.4]","[321.4, 123.5, 564.1, 764.1]"

我试图遵循Python中的列表字典转CSV的建议。 那更接近了,但不起作用,因为列的顺序是错误的:

代码:

    import csv
import StringIO
from itertools import izip_longest
outputFile=open('chan_press_prof.csv','wb')
dictPress={'600': [321.4, 123.5, 564.1, 764.1], '300': [12.7, 154.7, 327.5, 894.4], 'Position': [1,2,3,4]}
fields=['Position','300','600']
rows=izip_longest(*dictPress.values())
buf=StringIO.StringIO()
writeFile=csv.writer(outputFile)
writeFile.writerow(fields)
writeFile.writerows(rows)
outputFile.close()

并输出: 位置,300,600 12.7,1,321.4 154.7,2,123.5 327.5,3,564.1 894.4,4,764.1

请注意,位置值(1、2、3、4)不在正确的列中。

非常感谢您的帮助!

1个回答

4

我也想做同样的事情,以下是对我有用的方法。使用带有*运算符的zip对我很有效。同时注意writerow单数和writerows复数有助于将字典写入我想要的带有标题的文件中。

    zd = zip(*dictionary.values())
    with open('file.csv', 'w') as file:
        writer = csv.writer(file, delimiter=',')
        writer.writerow(dictionary.keys())
        writer.writerows(zd)

输出的结果如下所示,

gender,age,state,race,weights,educ
1,39,32,06,0.57,8
2,35,33,06,0.93,5
1,39,11,06,0.83,5

你只需将字典更改为包含你的数据的字典,示例应该完全一样。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接