使用fast-csv同步处理csv文件

时间:2016-07-14 10:03:04

标签: node.js csv

我正在尝试使用fast-csv处理csv文件,这是我的代码。

    var stream = fs.createReadStream("sample.csv");
    csv.fromStream(stream, {headers : true})
    .on("data", function(data) {
            console.log('here');
            module.exports.saveData(data, callback)
        })
    .on("end", function(){
        console.log('end of saving file');
    });

    module.exports.saveData = function(data) {
    console.log('inside saving')
    }

我面临的问题是流程不同步。 我看到的输出类似于

这里
这里
内部储蓄
内部保存

但是,我想要的是

这里
内部储蓄
这里
内部保存

我假设我们需要使用async.series或async.eachSeries但不完全确定如何在此处使用它。非常感谢任何投入

提前致谢!

1 个答案:

答案 0 :(得分:16)

您可以暂停解析器,等待saveData完成,然后恢复解析器:

var parser = csv.fromStream(stream, {headers : true}).on("data", function(data) {
  console.log('here');
  parser.pause();
  module.exports.saveData(data, function(err) {
    // TODO: handle error
    parser.resume();
  });
}).on("end", function(){
  console.log('end of saving file');
});

module.exports.saveData = function(data, callback) {
  console.log('inside saving')
  // Simulate an asynchronous operation:
  process.setImmediate(callback);
}