使用 "csv-parser" 节点 JS 解析 csv
Parse csv using "csv-parser" node JS
我正在使用 'csv-parser' 库。
使用下面的方法,我能够获取存储在控制台中显示的 birthdays 数组中的数据:
const birthdays = [];
fs.createReadStream('./data/groupes.csv')
.pipe(csv({}))
.on('data', (data) => birthdays.push(data))
.on('end', () => {
console.log(birthdays)
});
但是当我像下面这样在 .on('end')
之外登录时,控制台显示生日数组为空:
const birthdays = [];
fs.createReadStream('./data/groupes.csv')
.pipe(csv({}))
.on('data', (data) => birthdays.push(data))
.on('end', () => {
});
console.log(birthdays)
这是为什么?我该如何解决?
提前致谢。
你能做这样的事情吗?
const csv = require("csv-parser");
const fs = require("fs");
const path = require("path");
const { promisify } = require("util");
const readFile = promisify(fs.readFile);
const birthdays = [];
const filePath = path.join(__dirname, "data", "groupes.csv");
readFile(filePath, "utf8").then((data) => {
csv(data, {
separator: ",",
})
.on("data", (row) => {
birthdays.push(row);
})
.on("end", () => {
console.log(birthdays);
});
});
Why is that?
这是因为 createReadStream 是异步工作的,当你在外面 console.log(birthdays);
时,代码执行会在 createReadStream 完成处理之前读取日志
how can I solve it?
你把它放在 .on("end")
里面是正确的
const birthdays = [];
fs.createReadStream('./data/groupes.csv')
.pipe(csv({}))
.on('data', (data) => birthdays.push(data))
.on('end', () => {
console.log(birthdays);
// further processing with birthdays
});
我正在使用 'csv-parser' 库。 使用下面的方法,我能够获取存储在控制台中显示的 birthdays 数组中的数据:
const birthdays = [];
fs.createReadStream('./data/groupes.csv')
.pipe(csv({}))
.on('data', (data) => birthdays.push(data))
.on('end', () => {
console.log(birthdays)
});
但是当我像下面这样在 .on('end')
之外登录时,控制台显示生日数组为空:
const birthdays = [];
fs.createReadStream('./data/groupes.csv')
.pipe(csv({}))
.on('data', (data) => birthdays.push(data))
.on('end', () => {
});
console.log(birthdays)
这是为什么?我该如何解决? 提前致谢。
你能做这样的事情吗?
const csv = require("csv-parser");
const fs = require("fs");
const path = require("path");
const { promisify } = require("util");
const readFile = promisify(fs.readFile);
const birthdays = [];
const filePath = path.join(__dirname, "data", "groupes.csv");
readFile(filePath, "utf8").then((data) => {
csv(data, {
separator: ",",
})
.on("data", (row) => {
birthdays.push(row);
})
.on("end", () => {
console.log(birthdays);
});
});
Why is that?
这是因为 createReadStream 是异步工作的,当你在外面 console.log(birthdays);
时,代码执行会在 createReadStream 完成处理之前读取日志
how can I solve it?
你把它放在 .on("end")
里面是正确的const birthdays = [];
fs.createReadStream('./data/groupes.csv')
.pipe(csv({}))
.on('data', (data) => birthdays.push(data))
.on('end', () => {
console.log(birthdays);
// further processing with birthdays
});