我知道很多话题都是关于承诺和回调的。我尝试了很多方法,但仍然没有成功解决它。
我想要的是在本地编辑一个文件,保存然后上传到 S3。然后调用另一个函数从文件中读取并显示为列表
不幸的是,我遇到了错误,因为文件正在结束调用另一个函数来显示读取然后它正在写入并保存在 S3 中,正如您在我的 [终端][1] 中看到的 文件已正确编辑并上传到 s3
1- 我尝试使用 then 来执行一个又一个的承诺
static async edit_product(req: any, res: any) {
console.log('edit_product param request',req.body)
try {
ExcelFile.EditFile(prod.product_code,prod.product_name).then(rs=> res.status(200).json({'success'}) ) ).catch((err) => {
console.error(err);
})
console.log('test')
}
2- 使用等待然后
static async edit_product(req: any, res: any) {
console.log('edit_product param request',req.body)
try {
await ExcelFile.EditFile(prod.product_code,prod.product_name).then(rs=> rs)
console.log('test')
res.status(200).json({'success product edit':prod.product_code})
}
3-上传文件到S3
static async UploadFileS3() {
const file = config._path+config._foldername +config._filename
var s3 = new aws.S3({ accessKeyId: config._ACCESS_KEY_ID,secretAccessKey: config._SECRET_ACCESS_KEY });
var newversionId: string = ''
const params = {
Bucket: config._BUCKET_NAME,
Key: config._filename // File name you want to save as in S3
};
return s3.putObject(params, function(err, data) {
if (err) {console.log(err) }
newversionId = data.VersionId!
console.log("Successfully uploaded data ",newversionId);
});
};
4-编辑文件
const stream = new Stream.PassThrough();
var dataFile = wb.xlsx.readFile(file).then(rs=>{
var sh = rs.getWorksheet(config._sheetname);
for (let i = 2; i <= sh.rowCount; i++) {
let currRow = sh.getRow(i);
if (currRow.getCell(1).text==product_code){
currRow.getCell(2).value = product_name
currRow.commit();
break } }
console.log('edit ')
//save locally
wb.xlsx.writeFile(file).then(rs=>{console.log('edit filed successfully')});
const param = {Key: config._filename,
Bucket: config._BUCKET_NAME,
Body: stream,
ContentType: 'CONTENT_TYPE_EXCEL'
}
//save to s3
wb.xlsx.write(stream).then(() => {s3.upload(param, function (err,data) {
if (err) { console.log("Error", err); }
console.log("Upload Success", data.ETag);
ExcelFile.getAwsVersion().then(rs=>ExcelFile.saveFileBucketVersion(rs))
})
})
})
return dataFile //return promise
我怎样才能做到尊重步骤,先编辑然后返回 res.status(200).json({'success'} [1]:https://i.stack.imgur.com/SsWhu.png
答案 0 :(得分:0)
您的 EditFile 函数似乎没有等待 writeFile 的结束。 for 循环启动 writeFile
函数,但不会在那里等待。可能的解决方案是
将 write 函数移出 for 循环。无论如何,您可能会多次保存更改,这看起来很奇怪。
如果写入应该在循环中,那么在那里使用一个 promise 兼容的循环(例如 Bluebird.each
)