转换Node.js流的简洁方法



我正在尝试将换行符分隔的 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, 23, -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')
);

最新更新