从 csv 添加数字

Adding Numbers from csv

我正在尝试将一列中的所有数字添加到一个变量中。问题是我的代码正在将结果添加到 NaN 中。

var csvData=[];
    let test = 0;
    var parser = parse({delimiter: ','}, function(err, data){
    });

    fs.createReadStream(__dirname+'/test2.csv','utf16le').pipe(parser)
        .on('data', function(csvrow) {
            csvData.push(csvrow);
            test = test + (csvrow[2]);
        })
        .on('end',function() {
            console.log(test)
        });

给我:“0Daily Device Installs00001000101100”,如果我添加 parseInt(csvrow[2]) 我将得到 NaN 进行测试。

我的目标是在每日设备安装后添加所有数字,我缺少什么?

尝试

if (!isNaN(csvrow[2])) test += +csvrow[2];

我对 Node.js CSV package 做了一些研究。

使用header

如果您的 CSV 文件包含 header 行 ,如 comment by GrafiCode 中所假设的那样,如本例所示:

"Day","Daily Device Installs"
"2021-09-15",1
"2021-09-16",1

然后 CSV 解析器具有将 header 行与 column-names 一起使用的功能。 见 columns option.

好处:

  1. 记录 header
  2. 映射 column-names(为了在代码中简单使用)
  3. 用它来使您的代码简洁且富有表现力
  4. 防止输入 CSV
  5. 中 column-order 的变化
var csvData=[];
let test = 0;

// options: use default delimiter comma and map header
let parser = parse({
  columns: header =>
    header.map( column => {
      console.log(column);  
      // could also map (e.g. similar to Snake_Case)
      return column.replace(/ /g,"_");
    })
}

function addToCounter(value) {
   if (!isNaN(value))
      console.log("WARN: not a number: ", value)
      return;
   test += value;
}

// read from file
fs.createReadStream(__dirname+'/test2.csv','utf16le').pipe(parser)
   .on('data', function(csvrow) {
      csvData.push(csvrow);
      addToCounter(csvrow.Daily_Device_Installs); // the column name as mapped with underscore
   })
   .on('end',function() {
      console.log(test)
   });

注:

  • 我将 counter-increment 提取到函数中。
  • 您的 csvData 数组现在包含每行一个 object(以 column-names 作为键)而不是一个列数组。