如何利用python web框架做文件流下載的實現(xiàn)示例
hello 大家好, 前不久公司里有個需求,把時序數(shù)據(jù)庫中的日志下載到本地. 大家都知道. 數(shù)據(jù)庫里的數(shù)據(jù) 都是存在數(shù)據(jù)庫里的(廢話). 想把他下載到客戶的本地. 有的同學第一反應是: 只有文件才能下載. 所以大多數(shù)同學會想到先把數(shù)據(jù)從數(shù)據(jù)庫中讀出來,然后寫入到服務器中的某個文件夾下生成文件, 然后再下載. 其實這是非常不效率的方法, 最簡單的方法是,我們從數(shù)據(jù)庫中讀取到文件后, 直接以流的形式讓用戶去下載.
這里我拿python flask框架來做例子,其實非常簡單,步驟一共有3個
1: 取出數(shù)據(jù), 我們默認為json文件吧
2: 在response中加入指定的header
3: 將數(shù)據(jù)返回.
那么廢話少說,我們直接上代碼:
# coding:utf-8
import json
from flask import Flask, make_response
app = Flask(__name__)
@app.route('/download', methods=["GET"])
def download():user = {'name': 'dewei', 'age': 33}
data = json.dumps(user)
response = make_response(data)
response.headers['content-type'] = 'application/octet-stream;charset=utf-8'
response.headers['content-disposition'] = 'attachment;filename=user.json'
return response
if __name__ == '__main__':
app.run(host='0.0.0.0', port=5005, debug=True)
這是一個非常簡單的demo.
flask的定義我們不去關心了. 這里最重要的是獲取response, 并且在response的headers中,加入content-type 定義為octet-stream 流的操作. 另外一個key是 content-disposition ,這里主要定義文件的名稱. 這兩部完成之后,我們只需要return response即可, 重點就在這兩個header上,然后傳入數(shù)據(jù)信息(這里我們定義了一個json,大家也可以定義其他文件,比如excel,當然 excel請大家查詢一下對應的content-type. 還是非常簡單的, 這個方法對于任何web框架都是用, 比如 我們常用的 django, tornado web.py 都是一樣, 只不過語法在不同的框架里,方法名和用法可能有簡單區(qū)別,但換湯不換藥,原理是一樣的.
最后說一下用法,一般來說 下載的鏈接都是 get 所以前端只需要定義個 a標簽 添加 download屬性即可, demo如下:
<a href="xxxx/download" rel="external nofollow" download>文件下載</a>
到此這篇關于如何利用python web框架做文件流下載的實現(xiàn)示例的文章就介紹到這了,更多相關python 文件流下載內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
如何用 Python 子進程關閉 Excel 自動化中的彈窗
這篇文章主要介紹了如何用 Python 子進程關閉 Excel 自動化中的彈窗,幫助大家更好的理解和學習使用python,感興趣的朋友可以了解下2021-05-05
淺談python中字典append 到list 后值的改變問題
今天小編就為大家分享一篇淺談python中字典append 到list 后值的改變問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-05-05
python數(shù)據(jù)分析Numpy庫的常用操作
numpy 是 Python 的一個科學計算的庫,提供了矩陣運算的功能,其一般與 Scipy、matplotlib 一起使用,這篇文章總結下python數(shù)據(jù)分析Numpy庫的常用操作,感興趣的朋友一起看看吧2022-01-01

