Fastapi上传下载文件

1.上传文件 upload.py

from typing import List
from fastapi import FastAPI, File, UploadFile
from fastapi.responses import HTMLResponse
upload = FastAPI()

# 第一种读取文件方法,读取二进制文件
@upload.post("/files/")
async def create_files(files: List[bytes] = File(...)):
    # 保存文件名
    # with open('保存文件名字', 'wb') as f:
    #     f.write(files[0])
    return {"file_sizes": [len(file) for file in files]}

# 第二种读取文件的方法,会报错文件名,文件本身等信息
@upload.post("/uploadfiles/")
async def create_upload_files(files: List[UploadFile] = File(...)):
    
    # 保存文件
    # data = await files[0].read()
    # with open('保存文件名字', 'wb') as f:
    #     f.write(data)
    return {"filenames": [file.filename for file in files]}

@upload.get("/")
async def main():
    content = """
<body>
<form action="/files/" enctype="multipart/form-data" method="post">
<input name="files" type="file" multiple>
<input type="submit">
</form>
<form action="/uploadfiles/" enctype="multipart/form-data" method="post">
<input name="files" type="file" multiple>
<input type="submit">
</form>
</body>
    """
    return HTMLResponse(content=content)

if __name__ == '__main__':
    import uvicorn
    uvicorn.run('upload:upload', host='0.0.0.0', port=8900)

输入:http://0.0.0.0:8900/


上传文件

2.下载文件 download.py

import pandas as pd
from fastapi import FastAPI
from fastapi.responses import FileResponse,StreamingResponse,Response
import io

download = FastAPI()
file_path = "文件路径"

# 假设有个pandas DataFrame文件文件需要保存
@download.get("/from_data/")
def main():
    df = pd.DataFrame([1,2,3])
    stream = io.StringIO()
    df.to_csv(stream, index=False)
    response = StreamingResponse(iter([stream.getvalue()]), media_type="text/csv")
    response.headers["Content-Disposition"] = "attachment; filename=export.csv"
    return response

# 假设我们预定了文件的路径
@download.get("/from_path/")
def main():
    return FileResponse(path=file_path, filename=file_path, media_type='py')


if __name__ == '__main__':
    import uvicorn
    uvicorn.run('download:download', host='0.0.0.0', port=8800)

输入:http://0.0.0.0:8900/from_data/ 或者 http://0.0.0.0:8900/from_path/

下载文件

3.下载excel文件

# -*- coding: utf-8 -*-
"""
-------------------------------------------------
   File Name:     xxx
   Description :
   Author :       asdil
   date:          2022/5/11
-------------------------------------------------
   Change Activity:
                   2022/5/11:
-------------------------------------------------
"""
__author__ = 'Asdil'
import pandas as pd
from fastapi import FastAPI
from fastapi.responses import FileResponse,StreamingResponse,Response
import io

download = FastAPI()
file_path = "文件路径"

# 假设有个pandas DataFrame文件文件需要保存
@download.get("/from_data/")
def main():
    df = pd.DataFrame([1,2,3])
    stream = io.BytesIO()
    writer = pd.ExcelWriter(stream, engine='xlsxwriter')
    df.to_excel(writer, index=False)
    writer.save()
    xlsx_data = stream.getvalue()
    response = StreamingResponse(io.BytesIO(xlsx_data))
    response.media_type = 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'
    response.headers['Content-Disposition'] = f'attachment; filename="这里是你要保存的名字.xlsx"'.encode("utf-8").decode("latin1")
    return response


if __name__ == '__main__':
    import uvicorn
    uvicorn.run('xxx:download', host='0.0.0.0', port=8800)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • ftp 文件传输协议 跨平台 上传下载文件 vsftpd 工具:非常安全的文件传输协议;默认的命令端口21号,数据...
    柒夏锦阅读 9,538评论 1 9
  • 16宿命:用概率思维提高你的胜算 以前的我是风险厌恶者,不喜欢去冒险,但是人生放弃了冒险,也就放弃了无数的可能。 ...
    yichen大刀阅读 11,269评论 0 4
  • 公元:2019年11月28日19时42分农历:二零一九年 十一月 初三日 戌时干支:己亥乙亥己巳甲戌当月节气:立冬...
    石放阅读 11,800评论 0 2