我正在尝试将json转换为csv,并从我的flask应用程序下载文件。该功能无法正常工作,即使删除json文件,我也总是得到相同的csv。为什么?
按钮:
<a href="/download/wellness" class="btn btn-primary">Download</a>
我的方法:
@app.route("/download/<file_id>")
def get_csv(file_id):
try:
file_id = f"{file_id}"
filename_jsonl = f"{file_id}.jsonl"
filename_csv = f"{file_id}.csv"
file_id = ''
with open(filename_jsonl, 'r') as f:
for line in f.read():
file_id += line
file_id = [json.loads(item + '\n}') for item in file_id.split('}\n')[0:-1]]
with open(filename_csv, 'a') as f:
writer = csv.DictWriter(f, file_id[0].keys(), delimiter=";")
writer.writeheader()
for profile in file_id:
writer.writerow(profile)
return send_from_directory(directory='', filename=filename_csv, as_attachment=True)
except FileNotFoundError:
abort(404)
答案 0 :(得分:1)
您遇到的问题是第一个生成的文件已被缓存。
Official documentation表示send_from_directory()
使用send_file()
从给定目录发送文件。 send_file()
设置 cache_timeout 选项。
您必须配置此选项以禁用缓存,如下所示:
return send_from_directory(directory='', filename=filename_csv, as_attachment=True, cache_timeout=0)