golang处理excel打开csv乱码问题

最近在一个项目中导入导出csv文件的时候用excel打开都会出现乱码的情况,但是用number打开却是正常的,由此可知是编码问题导致。

在导入读取csv文件时,因为golang默认支持utf8编码,所以如果导入的csv文件不是utf8编码就会产生乱码,所以在读取文件的时候需要进行一个编码格式转换。

用到两个包:

"golang.org/x/text/encoding/simplifiedchinese"
"golang.org/x/text/transform"

然后将GBK编码转换为UTF8编码:

reader := transform.NewReader(bytes.NewReader(s), simplifiedchinese.GBK.NewDecoder())

 

同样,在导出的时候需要在csv文件的开头写入 UTF-8 BOM

    buf := new(bytes.Buffer)
	// BOM头,解决excel乱码问题
	buf.WriteString("\xEF\xBB\xBF")
	w := csv.NewWriter(buf)

这样之后用excel打开就不会出现乱码了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值