我在使用Express从csv文件发送JSON数据时遇到问题。它需要一个CSV文件的文件夹,循环,将其全部转换为JSON,然后在最后将其吐出,但在第一次加载后我收到错误Error: write after end
以及(node) warning: possible EventEmitter memory leak detected. 11 listeners added. Use emitter.setMaxListeners() to increase limit.
。该错误仅适用于我尝试点击/get
路径而不是主索引页面的时候。
我知道它与读取流关闭或未关闭有关,但我没有足够的知识来确切地知道该做什么。这是我的代码;任何建议都很可爱。的Ta!
Ps,使用的技术是Express,Node-walk和CSVtoJSON。
var _ = require('underscore')._;
var express = require('express');
var server = express();
server.use(express.static(__dirname + '/frontend/public/'));
server.listen(1234);
var getData = require('./src/getData.js');
server.get('/get', function (req, res) {
getData.get(function (data) {
res.send(data);
})
});
server.get('/', function (req, res) {
res.sendFile('./index.html');
});
var walk = require('walk');
var fs = require('fs');
var _ = require('underscore')._;
var csvtojson = require('csvtojson').core.Converter;
var files = [];
var csvConverter = new csvtojson({constructResult: true});
exports.get = function (callback) {
var csvWalker = walk.walk('./place-csvs-here', {followLinks: false});
csvWalker.on('file', function (root, stat, next) {
if (stat.name.match(/[A-Z]+?\-\d+?\.csv/gi)) {
var filename = root + '/' + stat.name;
files.push(fs.createReadStream(filename));
}
next();
});
csvWalker.on('end', function () {
files.forEach(function (file) {
file.pipe(csvConverter);
});
});
csvConverter.on('end_parsed', function (data) {
if (callback) {
// Ensure rows are unique.
data = _.uniq(data, function (x) {
return JSON.stringify(x);
});
// Required fields.
data = _.filter(data, function (x) {
return (
x['Date'] !== undefined
&& x['Balance'] !== undefined
&& x['Date'] !== 'Date'
&& x['Balance'] !== 'Balance'
);
});
callback(data);
}
});
}
答案 0 :(得分:5)
您正在尝试为所有请求重复使用files
和相同的csv转换器实例。您还尝试将多个文件同时传输到一个解析器实例。这可能会使解析器混淆。
请改为使用getData.js
:
var walk = require('walk');
var fs = require('fs');
var _ = require('underscore')._;
var csvtojson = require('csvtojson').core.Converter;
exports.get = function (callback) {
var csvWalker = walk.walk('./place-csvs-here', {followLinks: false});
var files = [];
var ret = [];
csvWalker.on('file', function (root, stat, next) {
if (stat.name.match(/[A-Z]+?\-\d+?\.csv/gi)) {
var filename = root + '/' + stat.name;
files.push(fs.createReadStream(filename));
}
next();
});
csvWalker.on('end', function () {
var left = files.length;
files.forEach(function (file) {
var csvConverter = new csvtojson({constructResult: true});
csvConverter.on('end_parsed', function (data) {
if (callback) {
if (--left === 0) {
// Ensure rows are unique.
ret = _.uniq(ret, function (x) {
return JSON.stringify(x);
});
// Required fields.
ret = _.filter(ret, function (x) {
return (
x['Date'] !== undefined
&& x['Balance'] !== undefined
&& x['Date'] !== 'Date'
&& x['Balance'] !== 'Balance'
);
});
callback(ret);
} else
ret = ret.concat(data);
}
});
file.pipe(csvConverter);
});
});
}
这假设由'end_parsed'上的csv转换器传入的data
始终是一个数组。它结合了所有文件中的数据,然后在执行回调之前运行数据过滤器。