我需要使用Node.js逐行解析以下格式的文件:
13
13
0 5
4 3
0 1
9 12
6 4
5 4
0 2
11 12
9 10
0 6
7 8
9 11
5 3
这代表一个图形。前两行是边和顶点的数量,其后是边。
我可以使用类似以下内容完成任务:
var fs = require('fs');
var readline = require('readline');
var read_stream = fs.createReadStream(filename);
var rl = readline.createInterface({
input: read_stream
});
var c = 0;
var vertexes_number;
var edges_number;
var edges = [];
rl.on('line', function(line){
if (c==0) {
vertexes_number = parseInt(line);
} else if (c==1) {
edges_number = parseInt(line);
} else {
edges.push(line.split(' '));
}
c++;
})
.on('end', function(){
rl.close();
})
我知道这种事情可能不是 Node.js 设计的初衷,但 line
回调中级联的 if
看起来并不优雅 / 可读。
是否有一种方式可以像其他编程语言那样同步从流中逐行读取?
如果没有内置的解决方案,我愿意使用插件。
[编辑]
抱歉,我应该更清楚地表明我想避免事先在内存中加载整个文件
fs.readFileSync
加载它,然后在按新行分割后同步地使用您的代码解析它,即lines = fs.readFileSync('graph.txt').split(/[\n\r]/);
。 - Nikos M.