2

我有一个烧瓶网站和一个生成 excel 文件的网络表单。我遇到的问题是,如果我将用户发送回表单再次提交,即使在 tmp 目录中生成了新文件,也会下载前一个文件(具有相同文件名和数据)。所以,我认为这与我的会话变量有关。

我使用此函数为文件名添加时间戳,以确保文件名是唯一的:

def rightnow():
    return dt.datetime.now().strftime("%m%d%y%h%m%S%f")

在 routes.py 中,这里是下载调用:

@app.route('/download/', methods=['POST','GET'])
def download_file():
    output_file = session.get('new_file', None)
    r = send_file(output_file, attachment_filename=output_file, as_attachment=True)
    return r

这是生成 excel 文件的脚本的代码:

new_file = 'output_' + rightnow() + '.xlsx'
writer = pd.ExcelWriter('tmp/' + new_file, engine='xlsxwriter')
df.to_excel(writer, sheet_name="data")      
writer.save()
session['new_file'] = 'tmp/' + new_file

模板页面的下载声明:

<a class="button" href="{{url_for('download_file')}}">Download new data</a>

我有一个与简单 javascript 相关的“再次提交”按钮

<button onclick="goBack()">Submit Again</button>
<script>//for "revise search" button
function goBack() {
    window.history.back();
}
</script>

我玩过session.clear()但没有成功。

当用户单击“再次提交”按钮以删除保存的文件名时,如何删除会话?

编辑:我检查了文件名和会话变量的变量,它们是相同的,并且与下载时分配的文件名不同。例如,我编写的脚本将该文件命名为“output_May0554733504.xlsx”——我可以在 tmp 目录中看到它。但是当我去下载文件时,文件名不同:'output_May0536794357.xlsx'

这个其他文件名不是 tmp 目录中其他文件的名称。我下载的任何文件都是“output_May0536794357.xlsx”。

4

1 回答 1

3

如果session.pop('new_file')不起作用,您可以尝试session.modified = True强制更改会话。

于 2019-06-01T08:36:32.723 回答