Python Flask - не возвращает вывод, если расширение файла xls - PullRequest
0 голосов
/ 30 октября 2018

У меня есть небольшой проект Flask, который получает некоторые входные данные от пользователя и извлекает некоторые данные из базы данных на основе входных данных обратно пользователю и возвращает выходной файл.

Код работает просто отлично, если формат файла csv. Однако, когда формат файла xls, я вижу генерируемый вывод, но приложение фляги не возвращает файл.

Отредактировано:

Ниже приведен код для views.py

@app.route('/data', methods=['GET','POST'])
def data():
    form = DataForm()
    if form.validate_on_submit():
        name = form.name.data
        start_date = form.start_date_field.data
        end_date = form.end_date_field.data
        file_extension = form.file_extension_field.data

        rep_func(name=name, start_date=start_date, end_date=end_date, exten=file_extension)

        current_directory = path.abspath(path.join(__file__, ".."))
        base = os.path.join(current_directory, 'files')

        if file_extension == 'csv':
            data = pd.read_csv(base + f'/final_output/{name}_{end_date}.{file_extension}', sep=r',(?!\s|\Z)', engine='python') 
            resp = make_response(data.to_csv(index=False))
            resp.headers["Content-Disposition"] = f'attachment; filename={name}_{end_date}.{file_extension}'
            resp.headers["Content-Type"] = "text/csv"
        elif file_extension == 'xls':
            data = pd.read_excel(base + f'/final_output/{name}_{end_date}.{file_extension}')
            resp = make_response(data.to_excel(index=False))
            resp.headers["Content-Disposition"] = f'attachment; filename={name}_{end_date}.{file_extension}'
            resp.headers["Content-Type"] = "application/vnd.ms-excel"
            return resp

    return render_template('file.html', form=form)

Может ли кто-нибудь посоветовать, где я ошибаюсь? Спасибо

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...