我正在尝试将换行符分隔的 JSON 文件转换为 CSV(有点愚蠢的任务,但没关系(,我很好奇如何在 node.js 中轻松做到这一点。到目前为止,我所拥有的是,
var csv = require('csv'),
fs = require('fs'),
JSONStream = require('JSONStream');
var stream = fs.createReadStream('input.json', {encoding: 'utf8'})
.pipe(JSONStream.parse());
csv().from(stream).to('out.csv');
这有效,但不允许我表达对键的排序。例如,如果我有一个这样的输入文件,
{"foo": 1, "bar": 2}
{"bar": 3, "foo": -1}
我想添加一个变形器函数,
function(line_object) { return [line_object.foo, line_object.bar]; };
这样我的输出将是第 1, 2
行和第 -1, 3
行,对应于foo
是第 1 列,bar
是第 2 列,而不是当前行为1, 2
和3, -1
。
但是,对于添加变压器,所有在线示例似乎都相当冗长。他们似乎创建了require('stream').Transform
对象,然后在这些对象上设置_transform
函数。问题:有没有更干净/更简洁的方法?非常感谢,请原谅我的无知,因为这几乎是我编写的第一个node.js
代码。
event-stream
可能很有用:
var fs = require('fs');
var csv = require('csv');
var JSONStream = require('JSONStream');
var es = require('event-stream');
es.pipeline(
fs.createReadStream('input.json'),
JSONStream.parse(),
es.map(function(data, next) {
next(null, [ data.foo, data.bar ]);
}),
csv().to('out.csv')
);