在继续之前等待承诺完成

问题描述

我知道很多话题都是关于承诺和回调的。我尝试了很多方法,但仍然没有成功解决它。

我想要的是在本地编辑一个文件,保存然后上传到 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,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

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)