如何将 Python 字典写入 csv 文件?[重复]
- 2025-02-10 08:57:00
- admin 原创
- 47
问题描述:
我有一个自认为非常简单的任务但我似乎无法解决。
如何将 Python 字典写入 csv 文件?我想要做的就是将字典键写入文件的第一行,将键值写入第二行。
我最接近的是以下内容(来自别人的帖子):
f = open('mycsvfile.csv','wb')
w = csv.DictWriter(f,my_dict.keys())
w.writerows(my_dict)
f.close()
问题是,上面的代码似乎只将键写入第一行,仅此而已。我没有将值写入第二行。
有什么想法吗?
解决方案 1:
您使用的DictWriter.writerows()
需要的是字典列表,而不是字典。您想要DictWriter.writerow()
写入一行。
DictWriter.writeheader()
如果您想要为 csv 文件添加标题,您还需要使用它。
您可能还想查看打开文件的语句。with
它不仅更具 Python 风格且可读性更强,而且即使发生异常也能为您处理关闭。
进行了这些更改的示例:
import csv
my_dict = {"test": 1, "testing": 2}
with open("mycsvfile.csv", "w", newline="") as f:
w = csv.DictWriter(f, my_dict.keys())
w.writeheader()
w.writerow(my_dict)
其结果为:
test,testing
1,2
正如评论中所述,我们使用newline=""
CSV 编写器进行自己的换行符管理,因此我们禁用了内置管理open()
,如文档中所述。
解决方案 2:
您的代码已经接近可以工作了。
尝试使用常规的csv.writer而不是DictWriter。后者主要用于编写字典列表。
下面是将每个键/值对写入单独行的代码:
import csv
somedict = dict(raymond='red', rachel='blue', matthew='green')
with open('mycsvfile.csv','w') as f:
w = csv.writer(f)
w.writerows(somedict.items())
如果您希望所有键都在一行上,所有值都在下一行上,这也很容易:
with open('mycsvfile.csv','w') as f:
w = csv.writer(f)
w.writerow(somedict.keys())
w.writerow(somedict.values())
专业提示:在开发此类代码时,将编写器设置为,w = csv.writer(sys.stderr)
以便您更轻松地查看正在生成的内容。当逻辑完善后,切换回w = csv.writer(f)
。
相关推荐
热门文章
项目管理软件有哪些?
热门标签
云禅道AD