博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
解决python中csv文件中文写入问题
阅读量:5145 次
发布时间:2019-06-13

本文共 722 字,大约阅读时间需要 2 分钟。

一、前言

一般来说,为了方便,使用python的时候都会使用csv模块去写数据到csv文件,但是写入中文的时候,经常会报错:

UnicodeEncodeError: 'ascii' codec can't encode characters in position 0-3: ordinal not in range(128)

我试过直接用utf8编码打开文件,然后直接将要写入的字段拼接为逗号分隔的字符串,虽然能解决中文写入的问题,但是操作很麻烦。而且直接使用excel打开的时候,还是会显示乱码。

用excel直接打开编码utf8编码的csv文件显示为乱码的原因,我推测是excel打开csv文件的时候,会先读取当前系统的默认编码作为读取csv文件的编码;而因为大家使用的一般都是中文系统,所以excel会使用gbk编码去读取文件,导致直接显示为乱码。

因此解决的点归结为一句话:

如何使用csv库,将中文写入gbk编码的csv文件。

 

二、解决

之前用过csv是没法成功的,后面才查到需要用unicodecsv才行。

直接上例子:

import unicodecsv as ucsvdata = [[u"列1", u"列2"], [u"内容1", u"内容2"]]with open('test.csv', 'wb') as f:    w = ucsv.writer(f, encoding = 'gbk')    w.writerows(data)

直接用文本编辑器打开效果:

用excel直接打开效果:

 

三、参考

1.

(完)

转载于:https://www.cnblogs.com/harrymore/p/10063775.html

你可能感兴趣的文章
快速切题 poj 1002 487-3279 按规则处理 模拟 难度:0
查看>>
判断线段是否相交
查看>>
Codeforces Round #277 (Div. 2)
查看>>
一步步学Mybatis-搭建最简单的开发环境-开篇(1)
查看>>
微信小程序图片上传
查看>>
【更新】智能手机批量添加联系人
查看>>
NYOJ-128前缀式计算
查看>>
centos6.7 配置外网端口映射
查看>>
红外通信基础(含代码)
查看>>
淡定,啊。数据唯一性
查看>>
java并发编程之lock锁
查看>>
深入理解 JavaScript 事件循环(一)— event loop
查看>>
Hive(7)-基本查询语句
查看>>
常用第三方(分享,支付,二维码,语音,推送)
查看>>
Redis快速入门
查看>>
动态绑定时的显示隐藏控制
查看>>
注意java的对象引用
查看>>
C++ 面向对象 类成员函数this指针
查看>>
inline函数的总结
查看>>
SPSS-生存分析
查看>>