Flask處理文件

1. 生成文件

我生成的是excel文件劣坊,所以我使用openpyxl來生成excel文件

1. 安裝openpyxl
pip install openpyxl
2. 簡單的示例
import openpyxl
import os

# 文件保存根目錄
FILE_PATH = '/home/kun/test'


def create_file(name):
    # 實例化
    wb = openpyxl.Workbook()
    # 激活worksheet
    ws = wb.active
    # 修改worksheet工作表名字
    ws.title = "測試數(shù)據(jù)"
    for i in range(50):
        # 使用append添加數(shù)據(jù)
        ws.append([i, name])
    # 保存文件,指定保存目錄以及文件名字
    wb.save(os.path.join(FILE_PATH, '{}.xlsx'.format(name)))


if __name__ == '__main__':
    create_file('測試')

運行后會生成對應文件缓待, 如下圖


生成的文件
3. 說明
  • 實例化
    wb = openpyxl.Workbook()
  • 激活worksheet
    ws = wb.active
  • 修改worksheet工作表名字
    ws.title = "xxxx"
  • 使用append添加數(shù)據(jù)
    ws.append([xx, xx, xx])
  • 保存文件岛杀,指定保存目錄以及文件名字
    wb.save(xxxxxx/yyyy.xlsx)

2. 返回文件

1. flask文件示例
import os

from urllib.parse import quote
from flask import Flask, send_file, request
from flask_cors import CORS

app = Flask(__name__)
CORS(app, supports_credentials=True)

# 文件保存根目錄
FILE_PATH = '/home/kun/test'

def create_file(name):
    # 實例化
    wb = openpyxl.Workbook()
    # 激活worksheet
    ws = wb.active
    # 修改worksheet工作表名字
    ws.title = "測試數(shù)據(jù)"
    for i in range(50):
        # 使用append添加數(shù)據(jù)
        ws.append([i, name])
    # 保存文件,指定保存目錄以及文件名字
    wb.save(os.path.join(FILE_PATH, '{}.xlsx'.format(name)))


@app.route('/upload')
def upload_file():
    # 接受參數(shù)
    name = request.args.get('name')
    # 使用openpyxl生成文件
    create_file(name)
    # 生成后的文件名字
    full_name = '{}.xlsx'.format(name)
    # 防止中文文件亂碼,原本的attachment_filename是沒有辦法用中文名的
    filename = quote(full_name)
    # 使用send_file
    rv = send_file(os.path.join(FILE_PATH, full_name), as_attachment=True, attachment_filename=filename)
    # 修改請求頭
    rv.headers['Content-Disposition'] += "; filename*=utf-8''{}".format(filename)
    # 返回文件對象
    return rv


if __name__ == '__main__':
    app.run(host='0.0.0.0', port=5010, debug=True)

2. 說明
  • 接受參數(shù)
    name = request.args.get('name')
  • 使用openpyxl生成文件
    create_file(name)
  • 生成后的文件名字
    full_name = '{}.xlsx'.format(name)
  • 防止中文文件亂碼昏鹃,原本的attachment_filename是沒有辦法用中文名的
    filename = quote(full_name)
  • 使用send_file
    rv = send_file(xxxx, as_attachment=True, attachment_filename=filename)
  • 修改請求頭
    rv.headers['Content-Disposition'] += "; filename*=utf-8''{}".format(filename)

3. 接收文件

1. flask示例文件
import os
from urllib.parse import quote
from flask import Flask, send_file, request, jsonify
from flask_cors import CORS

app = Flask(__name__)
CORS(app, supports_credentials=True)


@app.route('/receive')
def receive_file():
    # file就是接收file對象
    file = request.files.get('file')
    # file.filename 獲取文件名字
    filename = file.filename
    return jsonify({'filename': filename})


if __name__ == '__main__':
    app.run(host='0.0.0.0', port=5010, debug=True)

2. 說明
  • 接收file對象
    file = request.files.get('file')
  • 獲取文件名字
    filename = file.filename

4 .完整文件代碼

import os
import openpyxl
from urllib.parse import quote
from flask import Flask, send_file, request, jsonify
from flask_cors import CORS

app = Flask(__name__)
CORS(app, supports_credentials=True)

FILE_PATH = '/home/kun/test'


def create_file(name):
    # 實例化
    wb = openpyxl.Workbook()
    # 激活worksheet
    ws = wb.active
    # 修改worksheet工作表名字
    ws.title = "測試數(shù)據(jù)"
    for i in range(50):
        # 使用append添加數(shù)據(jù)
        ws.append([i, name])
    # 保存文件尚氛,指定保存目錄以及文件名字
    wb.save(os.path.join(FILE_PATH, '{}.xlsx'.format(name)))


@app.route('/upload')
def upload_file():
    # 接受參數(shù)
    name = request.args.get('name')
    # 使用openpyxl生成文件
    create_file(name)
    # 生成后的文件名字
    full_name = '{}.xlsx'.format(name)
    # 防止中文文件亂碼诀诊,原本的attachment_filename是沒有辦法用中文名的
    filename = quote(full_name)
    # 使用send_file
    rv = send_file(os.path.join(FILE_PATH, full_name), as_attachment=True, attachment_filename=filename)
    # 修改請求頭
    rv.headers['Content-Disposition'] += "; filename*=utf-8''{}".format(filename)
    # 返回文件對象
    return rv


@app.route('/receive')
def receive_file():
    # file就是接收的file對象
    file = request.files.get('file')
    # file.filename 獲取文件名字
    filename = file.filename
    return jsonify({'filename': filename})


if __name__ == '__main__':
    app.run(host='0.0.0.0', port=5010, debug=True)

最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市阅嘶,隨后出現(xiàn)的幾起案子属瓣,更是在濱河造成了極大的恐慌载迄,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,348評論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件抡蛙,死亡現(xiàn)場離奇詭異护昧,居然都是意外死亡,警方通過查閱死者的電腦和手機粗截,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,122評論 2 385
  • 文/潘曉璐 我一進店門惋耙,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人熊昌,你說我怎么就攤上這事绽榛。” “怎么了婿屹?”我有些...
    開封第一講書人閱讀 156,936評論 0 347
  • 文/不壞的土叔 我叫張陵灭美,是天一觀的道長。 經(jīng)常有香客問我昂利,道長届腐,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,427評論 1 283
  • 正文 為了忘掉前任蜂奸,我火速辦了婚禮犁苏,結果婚禮上,老公的妹妹穿的比我還像新娘扩所。我一直安慰自己傀顾,他們只是感情好,可當我...
    茶點故事閱讀 65,467評論 6 385
  • 文/花漫 我一把揭開白布碌奉。 她就那樣靜靜地躺著短曾,像睡著了一般。 火紅的嫁衣襯著肌膚如雪赐劣。 梳的紋絲不亂的頭發(fā)上嫉拐,一...
    開封第一講書人閱讀 49,785評論 1 290
  • 那天,我揣著相機與錄音魁兼,去河邊找鬼婉徘。 笑死,一個胖子當著我的面吹牛咐汞,可吹牛的內(nèi)容都是我干的盖呼。 我是一名探鬼主播,決...
    沈念sama閱讀 38,931評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼化撕,長吁一口氣:“原來是場噩夢啊……” “哼几晤!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起植阴,我...
    開封第一講書人閱讀 37,696評論 0 266
  • 序言:老撾萬榮一對情侶失蹤蟹瘾,失蹤者是張志新(化名)和其女友劉穎圾浅,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體憾朴,經(jīng)...
    沈念sama閱讀 44,141評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡狸捕,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,483評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了众雷。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片灸拍。...
    茶點故事閱讀 38,625評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖砾省,靈堂內(nèi)的尸體忽然破棺而出株搔,到底是詐尸還是另有隱情,我是刑警寧澤纯蛾,帶...
    沈念sama閱讀 34,291評論 4 329
  • 正文 年R本政府宣布纤房,位于F島的核電站,受9級特大地震影響翻诉,放射性物質(zhì)發(fā)生泄漏炮姨。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,892評論 3 312
  • 文/蒙蒙 一碰煌、第九天 我趴在偏房一處隱蔽的房頂上張望舒岸。 院中可真熱鬧,春花似錦芦圾、人聲如沸蛾派。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,741評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽洪乍。三九已至,卻和暖如春夜焦,著一層夾襖步出監(jiān)牢的瞬間壳澳,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評論 1 265
  • 我被黑心中介騙來泰國打工茫经, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留巷波,地道東北人。 一個月前我還...
    沈念sama閱讀 46,324評論 2 360
  • 正文 我出身青樓卸伞,卻偏偏與公主長得像抹镊,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子荤傲,可洞房花燭夜當晚...
    茶點故事閱讀 43,492評論 2 348