【发布时间】:2021-05-06 15:50:19
【问题描述】:
下面的代码在独立文件中运行时运行良好。但是当我尝试在我的 API 端点中使用它并向邮递员发送请求时,它似乎无法正常工作。
我不明白为什么。尝试使用相同的 API 端点编写 excel 文件时,我也遇到了同样的问题。如果我指定路径,它将找不到它。如果我只使用文件名,它会在当前目录中正常写入。
我错过了什么?下面的代码来自我在独立文件中使用它时的代码。如果我在下面的这条路线中使用它,它将无法工作。
exports.download_excel = async (req, res) => {....
完整代码如下
// modules import
const path = require('path');
const fs = require('fs');
const util = require('util');
const csv = require('@fast-csv/parse');
const { forEach } = require('p-iteration');
// const path = '../csv/';
const casesBO = [];
const readCSVFiles = async function() {
try {
const allLocalFiles = path.join('csv/');
const readDir = util.promisify(fs.readdir);
await readDir(allLocalFiles, async function(err, file) {
forEach(file, async item => {
fs.createReadStream('csv/' + item)
.pipe(csv.parse({ headers: true, delimiter: ';' }))
.on('error', error => console.error(error))
.on('data', async row => {
if (row['[REGION2]'] !== 'FR') {
casesBO.push(row['[CALLERNO_EMAIL_SOCIAL]']);
console.log(
`${row['[AGENT]']} is ${row['[REGION2]']} and case = ${
row['[CALLERNO_EMAIL_SOCIAL]']
}`
);
}
})
.on('end', async rowCount => {});
});
});
} catch (error) {
console.log(error);
}
};
【问题讨论】:
标签: javascript node.js express path