0

我正在尝试将列中的所有数字添加到变量中。问题是我的代码正在将结果添加到 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 进行测试。

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

4

2 回答 2

1

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

使用标题

如果您的 CSV 文件包含GrafiCode 注释中假定的标题行,例如在此示例中:

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

然后 CSV Parser 具有将标题行与列名一起使用的功能。请参阅columns选项

益处:

  1. 记录标题
  2. 映射列名(用于代码中的简单使用)
  3. 用它来让你的代码干净且富有表现力
  4. 防止输入 CSV 中列顺序的变化
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)
   });

笔记:

  • 我将反增量提取到一个函数中。
  • 您的csvData数组现在为每一行包含一个对象(以列名作为键)而不是一个列数组。
于 2021-09-17T14:17:57.803 回答
0

尝试

if (!isNaN(csvrow[2])) test += +csvrow[2];
于 2021-09-17T11:13:44.197 回答