从 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.
好处:
- 记录 header
- 映射 column-names(为了在代码中简单使用)
- 用它来使您的代码简洁且富有表现力
- 防止输入 CSV
中 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 作为键)而不是一个列数组。
我正在尝试将一列中的所有数字添加到一个变量中。问题是我的代码正在将结果添加到 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.
好处:
- 记录 header
- 映射 column-names(为了在代码中简单使用)
- 用它来使您的代码简洁且富有表现力
- 防止输入 CSV 中 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 作为键)而不是一个列数组。