![](/img/trans.png)
[英]How do I use await/async in fs.createReadStream/csv-parser using Promises?
[英]How should I return data from fs.createReadStream() using csv parser
我有这个功能
function getData(file, type) {
let data = [];
fs.createReadStream(file)
.pipe(csv({headers: false, separator: ';',}))
.on('data', (row) => {
let item = {
date: row[0],
value: row[1]
};
let item2 = {
date: moment(row[0], "DD-MM-YYYY HH:mm").add(30, "minutes").format("DD/MM/YYYY HH:mm"),
value: row[2]
};
data.push(item);
data.push(item2);
})
.on('end', () => {
return data;
});
}
我想返回csv中解析的数据,但是当我在.on
方法中返回数据时,数据为空。
我该怎么做?
我建议使用基于承诺的方法,您可以从 getData 函数返回一个承诺,然后根据需要解决或拒绝。
这使调用函数的事情变得更加清晰。
例如:
function getData(file, type) {
let data = [];
return new Promise((resolve, reject) => {
fs.createReadStream(file)
.on('error', error => {
reject(error);
})
.pipe(csv({headers: false, separator: ';',}))
.on('data', (row) => {
let item = {
date: row[0],
value: row[1]
};
let item2 = {
date: moment(row[0], "DD-MM-YYYY HH:mm").add(30, "minutes").format("DD/MM/YYYY HH:mm"),
value: row[2]
};
data.push(item);
data.push(item2);
})
.on('end', () => {
resolve(data);
});
});
}
async function testGetData() {
try {
const data = await getData("test.csv", {});
console.log("testGetData: parsed CSV data:", data);
} catch (error) {
console.error("testGetData: An error occurred: ", error.message);
}
}
testGetData();
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.