一、前言
在Linux下面用python进行数据处理,然后输出为csv格式,如果没有中文一切正常,但是如果有中文,就会出现乱码的问题
二、处理过程
#!/usr/bin/envpython #-*-coding:UTF-8-*- importcsv #importcodecs withopen('test.csv','wb')ascsvfile: #csvfile.write(codecs.BOM_UTF8) spamwriter=csv.writer(csvfile,dialect='excel') spamwriter.writerow(['测试']*5+['BakedBeans']) spamwriter.writerow(['Spam','LovelySpam','WonderfulSpam'])
运行以后:
Linux下的效果
[root@lab8106 ~]# cat test.csv
测试,测试,测试,测试,测试,Baked Beans
Spam,Lovely Spam,Wonderful Spam
Windows下打开的效果
#!/usr/bin/envpython #-*-coding:UTF-8-*- importcsv importcodecs withopen('test.csv','wb')ascsvfile: csvfile.write(codecs.BOM_UTF8) spamwriter=csv.writer(csvfile,dialect='excel') spamwriter.writerow(['测试']*5+['BakedBeans']) spamwriter.writerow(['Spam','LovelySpam','WonderfulSpam'])
跟上面的代码相比,引入了两行代码
importcodecs csvfile.write(codecs.BOM_UTF8)
我们再来看效果Linux下的效果
[root@lab8106 ~]# cat test.csv
测试,测试,测试,测试,测试,Baked Beans
Spam,Lovely Spam,Wonderful Spam
Windows下打开的效果
原文来自:https://www.py.cn
© 版权声明
文章版权归作者所有,未经允许请勿转载。
THE END
暂无评论内容