Python中文
首页
教程
问答
标签
搜索
登录
注册
用Python编写一个.CSV文件,该文件在Windows中同时适用于Python 2.7+和Python 3.3+
回答此问题可获得
20
贡献值,回答如果被采纳可获得
50
分。
<p>编辑:我把它放在标题里,但我才意识到我没有在正文里提到它。这似乎是Windows特有的。</p> <p>在同时使用Python 2.7和3.3的脚本中,我很难使用<code>csv</code>Python模块编写输出。</p> <p>首先尝试在Python2.7中按预期工作:</p> <pre><code>with open('test.csv', 'wb') as csv_file: writer = csv.DictWriter(csv_file, ['header1', 'header2']) writer.writeheader() for item in items: writer.writerow(item) </code></pre> <p>但是,当在Python3.3中运行相同的程序时,您将得到:</p> <pre><code>TypeError: 'str' does not support the buffer interface </code></pre> <p>所以我将<code>'wb'</code>更改为<code>'wt'</code>并运行它,但是现在文件中每隔一行有一个额外的空行。</p> <p>为了解决这个问题,我改变了:</p> <pre><code>with open('test.csv', 'wt') as csv_file: </code></pre> <p>致:</p> <pre><code>with open('test.csv', 'wt', newline='') as csv_file: </code></pre> <p>但现在,它打破了Python2.7:</p> <pre><code>TypeError: 'newline' is an invalid keyword argument for this function </code></pre> <p>我知道我可以这样做:</p> <pre><code>try: with open('test.csv', 'wt', newline='') as csv_file: writer = csv.DictWriter(csv_file, ['header1', 'header2']) writer.writeheader() for item in items: writer.writerow(item) except TypeError: with open('test.csv', 'wb') as csv_file: writer = csv.DictWriter(csv_file, ['header1', 'header2']) writer.writeheader() for item in items: writer.writerow(item) </code></pre> <p>然而,这有一些严重的重复。</p> <p>有没有人有更干净的方法来做这件事?</p> <p>编辑:测试数据很简单,没有换行符或任何内容:</p> <pre><code>items = [{'header1': 'value', 'header2': 'value2'}, {'header1': 'blah1', 'header2': 'blah2'}] </code></pre>
0 条评论
分类:
Python问答
请先
登录
后评论
默认排序
时间排序
1 个回答
匿名
1天前
擅长:python、mysql、java
<p>我试过几种方法。据我所见,简单地使用<code>'w'</code>可能是一个解决方案:</p> <pre><code>with open('test.csv', 'w') as csv_file: writer = csv.DictWriter(csv_file, fieldnames=['header1', 'header2'], lineterminator='\n') # write something </code></pre>
请先
登录
后评论
针对此问题:
更多的回答
关注
89
关注
收藏
1
收藏,
216
浏览
网友 提问于 2天前
相关Python问题
尽管Python中的所有内容都是引用,为什么Python导师在没有指针的列表中绘制字符串和整数?
1 回答
尽管python中的表达式为false,但循环仍在运行
1 回答
尽管python代码正确,但从nifi ExecuteScript处理器获取语法错误
2 回答
尽管Python在Neovim中工作得很好,但插件不能识别Neovim中的Python主机
9 回答
尽管python字典包含了大量的条目,但它并没有增长
6 回答
尽管python说模块存在,为什么我会得到这个消息?
8 回答
尽管setuptools和控制盘是最新的,但无法识别singleversionexternallymanaged
8 回答
尽管stdout和stderr重定向,但未捕获错误消息
10 回答
尽管Tensorboard的事件太大,但Tensorboard的步骤太少了
7 回答
尽管tkinter上的变量已更改,但显示未更改
10 回答
尽管try/except使用Python进行单元测试时出现断言错误
6 回答
尽管URL是sam,但仍会抛出“达到最大重定向”
2 回答
尽管url有效,Pandas仍读取url的\u csv错误
3 回答
尽管while中存在时间延迟,但LINUX线程的CPU利用率为100%(1)
1 回答
尽管x0在范围内,Scipy优化仍会引发ValueError
9 回答
尽管xpath正确,但使用selenium单击链接仍不起作用
9 回答
尽管下载了ffmpeg并设置了路径变量python,但没有后端错误
4 回答
尽管下载了i,但找不到型号“fr”
8 回答
尽管下载了plotnine包,但未获取名为“plotnine”的模块时出错
3 回答
尽管为所有行指定了权重,网格(0)仍不起作用
10 回答