前言
之前有个项目中使用到了一个前端的download.js
库,主要是用来拼接内容然后生成一个.txt
或者.csv
等文件让用户下载,不过目前这个库不支持了chrome
和safari
等webkit
内核的浏览器了。而且下载的内容如果有中文字符的话还有乱码的现象。
用 Node.js 生成 csv 文件
想使用Node.js
来生成 csv 文件的话,可以自己拼接好内容后通过fs.writeFile
来写入一个文件。不过还是有个问题,如果有中文字符的还是会出现乱码的情况。
接下来就是介绍一下两个库可以解决我们的问题,一个是json2csv
可以通过json
的数据去生成csv
文件的内容,然后在fs.writeFile
,另外一个库则是iconv-lite
用来把内容的编码转换为GBK
格式,这样一来就能够解决中文乱码的问题。
还有一个值得一提的,就是有其他的小伙伴会用iconv
这个库,不过我发现我使用npm
还是cnpm
都安装不上,所以就使用了iconv-lite
这个库。可以注意一下这个问题。
贴一个实例:
var json2csv = require('json2csv');
var iconv = require('iconv-lite');
var fs = require('fs');
var fields = ['field1', 'field2', 'field3']; // 这里的内容是不支持中文的。
var myData = {
'field1': 'field1',
'field2': 'field2',
'field3': 'field3',
};
json2csv({ data: myData, fields: fields }, function(err, csv) {
if (err) console.log(err);
var newCsv = iconv.encode(csv, 'GBK'); // 转编码
fs.writeFile('demo.csv', newCsv, function (err) {
if (err) console.log(err);
console.log('Saved done!');
});
});