在继续之前等待承诺完成

时间:2021-02-18 04:27:12

标签: async-await promise callback aws-sdk exceljs

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

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

1 个答案:

答案 0 :(得分:0)

您的 EditFile 函数似乎没有等待 writeFile 的结束。 for 循环启动 writeFile 函数,但不会在那里等待。可能的解决方案是

  1. 将 write 函数移出 for 循环。无论如何,您可能会多次保存更改,这看起来很奇怪。

  2. 如果写入应该在循环中,那么在那里使用一个 promise 兼容的循环(例如 Bluebird.each