在Linux下面用python进行数据处理,然后输出为csv格式,如果没有中文一切正常,但是如果有中文,就会出现乱码的问题,本篇将讲述怎么处理这个问题
#!/usr/bin/env python # -*- coding: UTF-8 -*- import csv #import codecs with open('test.csv', 'wb') as csvfile: # csvfile.write(codecs.BOM_UTF8) spamwriter = csv.writer(csvfile, dialect='excel') spamwriter.writerow(['测试'] * 5 + ['Baked Beans']) spamwriter.writerow(['Spam', 'Lovely Spam', 'Wonderful Spam']) |
运行以后:
Linux下的效果
[root@lab8106 ~]# cat test.csv 测试,测试,测试,测试,测试,Baked Beans Spam,Lovely Spam,Wonderful Spam |
#!/usr/bin/env python # -*- coding: UTF-8 -*- import csv import codecs with open('test.csv', 'wb') as csvfile: csvfile.write(codecs.BOM_UTF8) spamwriter = csv.writer(csvfile, dialect='excel') spamwriter.writerow(['测试'] * 5 + ['Baked Beans']) spamwriter.writerow(['Spam', 'Lovely Spam', 'Wonderful Spam']) |
跟上面的代码相比,引入了两行代码
import codecs
csvfile.write(codecs.BOM_UTF8)
我们再来看效果Linux下的效果
[root@lab8106 ~]# cat test.csv 测试,测试,测试,测试,测试,Baked Beans Spam,Lovely Spam,Wonderful Spam |
网上找了一些资料,这个方式比较快而简单,就先用这个方式解决,方法有很多
Why |
Who | When |
---|---|---|
创建 | 武汉-运维-磨渣 | 2016-09-28 |