如何利用python web框架做文件流下載的實(shí)現(xiàn)示例
hello 大家好, 前不久公司里有個(gè)需求,把時(shí)序數(shù)據(jù)庫中的日志下載到本地. 大家都知道. 數(shù)據(jù)庫里的數(shù)據(jù) 都是存在數(shù)據(jù)庫里的(廢話). 想把他下載到客戶的本地. 有的同學(xué)第一反應(yīng)是: 只有文件才能下載. 所以大多數(shù)同學(xué)會(huì)想到先把數(shù)據(jù)從數(shù)據(jù)庫中讀出來,然后寫入到服務(wù)器中的某個(gè)文件夾下生成文件, 然后再下載. 其實(shí)這是非常不效率的方法, 最簡單的方法是,我們從數(shù)據(jù)庫中讀取到文件后, 直接以流的形式讓用戶去下載.
這里我拿python flask框架來做例子,其實(shí)非常簡單,步驟一共有3個(gè)
1: 取出數(shù)據(jù), 我們默認(rèn)為json文件吧
2: 在response中加入指定的header
3: 將數(shù)據(jù)返回.
那么廢話少說,我們直接上代碼:
# coding:utf-8import 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)
這是一個(gè)非常簡單的demo.
flask的定義我們不去關(guān)心了. 這里最重要的是獲取response, 并且在response的headers中,加入content-type 定義為octet-stream 流的操作. 另外一個(gè)key是 content-disposition ,這里主要定義文件的名稱. 這兩部完成之后,我們只需要return response即可, 重點(diǎn)就在這兩個(gè)header上,然后傳入數(shù)據(jù)信息(這里我們定義了一個(gè)json,大家也可以定義其他文件,比如excel,當(dāng)然 excel請(qǐng)大家查詢一下對(duì)應(yīng)的content-type. 還是非常簡單的, 這個(gè)方法對(duì)于任何web框架都是用, 比如 我們常用的 django, tornado web.py 都是一樣, 只不過語法在不同的框架里,方法名和用法可能有簡單區(qū)別,但換湯不換藥,原理是一樣的.
最后說一下用法,一般來說 下載的鏈接都是 get 所以前端只需要定義個(gè) a標(biāo)簽 添加 download屬性即可, demo如下:
<a href='http://m.4tl426be.cn/bcjs/xxxx/download' rel='external nofollow' download>文件下載</a>
到此這篇關(guān)于如何利用python web框架做文件流下載的實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)python 文件流下載內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. Java GZip 基于內(nèi)存實(shí)現(xiàn)壓縮和解壓的方法2. idea配置jdk的操作方法3. SpringBoot+TestNG單元測(cè)試的實(shí)現(xiàn)4. IntelliJ IDEA設(shè)置默認(rèn)瀏覽器的方法5. python 浮點(diǎn)數(shù)四舍五入需要注意的地方6. Springboot 全局日期格式化處理的實(shí)現(xiàn)7. VMware中如何安裝Ubuntu8. Docker容器如何更新打包并上傳到阿里云9. 完美解決vue 中多個(gè)echarts圖表自適應(yīng)的問題10. JAMon(Java Application Monitor)備忘記
