使用 flask 下载文件
通过这个解释,我们将学习如何使用 flask 中的 send_file
函数创建可下载链接以将文件下载为附件。
在 flask 的 send_file
函数的帮助下将文件作为附件下载
在 flask framework 中,我们可以制作一个文件下载器来下载各种文件,如 pdf、jpeg、mp3 或其他文件,但逻辑保持不变。现在我们只需要转到我们的文本编辑器并在我们的 png 文件所在的同一目录中创建一个简单的 app.py
文件。
现在我们还需要创建一个模板文件夹,在其中,我们将创建一个 index.html
文件,就是这样。现在,首先,我们需要导入 flask 库。
你只需要一些必需的库和 send_file
库:
from flask import flask,render_template,send_file
我们需要创建一个 app
变量并使用 __name__
属性初始化 flask 应用程序。现在我们将初始化我们的主函数,我们只需要在这个块中调用 run
函数并将 debug
等于 true
传递给它,所以每当我们进行更改时它都会重新启动应用程序。
app = flask(__name__)
if __name__=='__main__':
app.run(debug=true)
我们必须创建一个路由和一个函数来加载 html 文件。为此,我们将创建一个名为 /
的主路由,当我们点击此路由时,它将调用一个名为 main_page()
的函数。
该函数返回 render_template()
;在其中,我们将传递 index.html
文件,该文件将加载存储在 index.html
文件中的模板。
@app.route('/')
def main_page():
return render_template('index.html')
现在我们将编写一个基本模板来保存下载的文件。
我们将只使用几个标签,第一个是包含标题的
标签,第二个是作为段落标签的
标签。在这个标签中,我们将使用 anchor 标签,并且
href
属性将等于 url_for
属性,并将其名称传递给它。
<h2>downloqad this fileh2>
<p> <a href="{{url_for('download_file')}}">downloada>p>
如果我们运行这个应用程序并打开 localhost 5000
,它会告诉我们它无法为端点 download_file
构建 url。
这个语法 url_for('download_file')
正在寻找一个下载文件,所以我们只需要发出一个 get 请求就可以了。
现在我们将创建另一个路由,/download
。我们将创建一个与我们在 url_for()
属性中指定的名称相同的函数。
现在我们需要指定文件的路径,因此我们将创建一个变量,将其命名为 path
,并将路径存储在该变量中。
我们将使用 send_file()
函数返回文件,该函数有两个参数。第一个是路径,第二个是 as_attachment
等于 true
因为我们希望将可下载文件作为附件。
@app.route('/download')
def download_file():
path='flask-logo.png'
send_file(path,as_attachment=true)
如果我们保存并刷新页面,我们会看到它被转换为一个超链接,我们可以通过点击这个链接来下载文件。
完整的 python 代码:
from flask import flask,render_template,send_file
app = flask(__name__)
@app.route('/')
def main_page():
return render_template('index.html')
@app.route('/download')
def download_file():
path='flask-logo.png'
return send_file(path,as_attachment=true)
if __name__=='__main__':
app.run(debug=true)
转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处
本文地址:
相关文章
pandas dataframe dataframe.shift() 函数
发布时间:2024/04/24 浏览次数:133 分类:python
-
dataframe.shift() 函数是将 dataframe 的索引按指定的周期数进行移位。
python pandas.pivot_table() 函数
发布时间:2024/04/24 浏览次数:82 分类:python
-
python pandas pivot_table()函数通过对数据进行汇总,避免了数据的重复。
pandas read_csv()函数
发布时间:2024/04/24 浏览次数:254 分类:python
-
pandas read_csv()函数将指定的逗号分隔值(csv)文件读取到 dataframe 中。
pandas 多列合并
发布时间:2024/04/24 浏览次数:628 分类:python
-
本教程介绍了如何在 pandas 中使用 dataframe.merge()方法合并两个 dataframes。
pandas loc vs iloc
发布时间:2024/04/24 浏览次数:837 分类:python
-
本教程介绍了如何使用 python 中的 loc 和 iloc 从 pandas dataframe 中过滤数据。
在 python 中将 pandas 系列的日期时间转换为字符串
发布时间:2024/04/24 浏览次数:894 分类:python
-
了解如何在 python 中将 pandas 系列日期时间转换为字符串