欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

ruby on rails 导出csv中文乱码——神奇的\xEF\xBB\xBF

程序员文章站 2022-03-02 23:49:20
...

最近弄csv导出,碰到了中文乱码问题。折腾了很久,一两天去了。

试过几个库都碰到编码的问题。

也用到了fastercsv(ruby1.9.2已添加到标准库为csv,require 'csv'),导出一样乱码,有高手说

output = NKF.nkf("-wLuxs",output)        #转化编码格式

 

 

用这个来转换,但是我试了,在我的项目中反正是没有效果。(这里是用到nkf库,require 'nkf')

 

后面看到有人说要加个这个:

head = ‘EF BB BF’.split(' ').map{|a|a.hex.chr}.join()

 

看起来好高深- -!这么复杂~。~

不过加进去还真起效果了。但是怎么个加进去。是个问题:

我用fastercsv,把上面这个head加到第一行,乱码问题解决了,但是csv文件多了一空行。这显然不行。然后又是折腾如何把我内容的头部放到第一行。。。倍感这东西太坑了。

 

其实:

 

一切也没多难,就是我们需要给导出的csv开头加个BOM(我这里导出的格式使用utf8),也就是要加个16进制串:“\xEF\xBB\xBF”。上面的head的值其实就是这个串,搞那么复杂,吓倒我了!!

 

到现在应该就明了了,就是在csv文件最开始加上“\xEF\xBB\xBF”,比如我的csv中有个头部,我就加到头部:

header: ["\xEF\xBB\xBF姓名",'手机','']

 

这里要注意的是ruby字符串可以用单引号,和双引号。区别就不多说了,这里引用16进制串的就必须用双引号,其他的没事,你懂的。写好点可以封装一下。

 

至此搞定!其他什么都不要弄,就在开始加个\xEF\xBB\xBF,这个需要放到双引号中.

 

当然,这不是最好的方案。但是~管用~ 不管你有没有用,我反正是有用了^_^ ~。

 

参考:

http://www.zhouwenyi.com/node/10087

 

http://*.com/questions/155097/microsoft-excel-mangles-diacritics-in-csv-files