使用“csv-parser”节点JS解析csv

问题描述 投票:0回答:3

我正在使用“csv-parser”库。 使用下面的方法,我可以获取存储在控制台中显示的生日数组中的数据:

    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)

这是为什么呢?我该如何解决这个问题? 预先感谢。

javascript node.js arrays csv csv-parser
3个回答
2
投票

这是为什么?

这是因为 createReadStream 是异步工作的,当你在外面

console.log(birthdays);
时,代码执行会在 createReadStream 完成处理之前读取日志

我该如何解决?

你把它放在 .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
  });

0
投票

你能做这样的事吗?

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);
    });
});

0
投票

您还可以使用“csv-for-you”npm 包

const {parseCsv} = require('csv-for-you')
async function muFunction(){
  const birthdays = await parseCsv('path/to/file'); 
  console.log(birthdays)
}
© www.soinside.com 2019 - 2024. All rights reserved.