我有一个烧瓶网站和一个生成 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”。