前提・実現したいこと
flaskでバックエンドAPIを作り始めたPython初級者です。
DB検索結果が0ならダウンロードせず、メッセージを返却したいです。
しかし、何故かIF文が無視されて、空ファイルが必ずDLされます。
1つのAPIで、メッセージ返却とDLは両立出来ないのでしょうか。
どのような解決方法でも構わないので、ご指導頂ければ幸いです。
該当のソースコード
Python
1@app.route('/download', methods=['POST']) 2@cross_origin(supports_credentials=True) 3def download(): 4 5 try: 6 req = request.get_json() 7 res = DataBase.get(**req) 8 9 if res: 10 11 path = MakeExcel(res) 12 mime = 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' 13 return send_file(path, as_attachment=True, attachment_filename=name, mimetype=mime) 14 15 else: 16 raise Exception('Empty') 17 18 except Exception as e: 19 return make_response(jsonify('{status:NG}'))
試したこと
ダウンロード部分をコメントアウトすると、ちゃんとelseの方に流れます。
補足情報(FW/ツールのバージョンなど)
Flask, sqlalchemy, openpyxl
ここにより詳細な情報を記載してください。
あなたの回答
tips
プレビュー