python CSV模块 写入CSV文件时,0开头的数字会丢失
# _*_ coding:utf-8 _*_
#win7+python2.7.x
import csv
csvfile = file('csvtest.csv', 'wb')
writer = csv.writer(csvfile)
writer.writerow(['id', 'url', 'keywords'])
data = [
('0011', 'http://www.59store.com/', '59store.com'),
('0022', 'http://59data.top/', '59data.top'),
('0033', 'http://my.space.zmx/', '汉子乱码?')
]
writer.writerows(data)
csvfile.close()
写入CSV时会丢失0字头,汉字乱码
是 Excel 的问题。
Excel 会自己猜测是否是一个数字列,如果是数字列,默认是会按数字显示(省略0)。
Excel 默认格式为本地字符集(简体中文版是
gbk
),它无法自动识别无BOM格式的
utf8
格式,除非在文件前面加上3字符的BOM头。(在 office 2007 下的某个版本,对有BO