FastAPI文件下载实现

FastAPI文件下载实现

在这里插入图片描述

下载文件(以下载Excel为例)

一、包下载

pip install fastapi
pip install uvicorn
pip install aiofiles 

// 操作Excel的包
pip install pandas
pip install openpyxl

二、准备Excel文件(使用pandas创建Excel并且保存到项目中,为下载文件做准备)

result = [
    {
        "id": 1,
        "name": "xxx",
        "age": 18
    }, {
        "id": 2,
        "name": "bbb",
        "age": 19
    }
]
file = str(datetime.datetime.now().date())+".xlsx"
df = pandas.DataFrame(result)
df.columns = ["序号", "姓名", "年龄"]
df.to_excel(file, index=False)

三、下载文件

  • 直接返回FileResponse
    • 参数1:文件的路径
    • filename:自定义导出的文件名(需要带上格式后缀)
# file:就是第二步创建的Excel文件路径
return FileResponse(file, filename="user.xlsx")

四、完整代码

import datetime
from fastapi import FastAPI

import pandas
from starlette.responses import FileResponse

app = FastAPI()

@app.get("/download", summary="下载文件")
async def download_file():
    result = [
        {
            "id": 1,
            "name": "xxx",
            "age": 18
        }, {
            "id": 2,
            "name": "bbb",
            "age": 19
        }
    ]
    file = str(datetime.datetime.now().date())+".xlsx"
    df = pandas.DataFrame(result)
    df.columns = ["序号", "姓名", "年龄"]
    df.to_excel(file, index=False)
    return FileResponse(file, filename="user.xlsx")

if __name__ == "__main__":
    import uvicorn
    uvicorn.run(app, host="127.0.0.1", port=8080)

五、演示效果

在这里插入图片描述

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
文本格式不能很好显示,请见谅(附件里有比较齐整的excel表格统计) 大小类型 传输类型 api方法 文件大小 花费时间 速率byte/ms 速率mb/s 缓存数组 次数 备注 大文件 下载 download_file(group_name, remote_filename, localFile) 1073741824(约1G) 28343ms 37883 36.12804413 无 1 下载 download_file(group_name, remote_filename , downloadStream) 1073741824(约1G) 29195ms 36778 35.07423401 0 1 fastDFS的DownloadStream,FileOutputStream 下载 download_file(group_name, remote_filename , downloadStream) 1073741824(约1G) 24352ms 44092 42.04940796 2K 1 fastDFS的DowloadStream,BufferedOutputStream 下载 download_file(group_name, remote_filename , DownloadCallback) 1073741824(约1G) 24831ms 43241 41.23783112 2K 1 实现DownloadCallback,BufferedOutputStream 下载 download_file(group_name, remote_filename , DownloadCallback) 1073741824(约1G) 25922ms 41422 39.50309753 8K 1 实现DownloadCallback,BufferedOutputStream 普通文件 下载 download_file(group_name, remote_filename, localFile) 59113472(约56M) 382ms 154747 147.5782394 无 1 下载 download_file(group_name, remote_filename , downloadStream) 59113472(约57M) 369ms 160199 152.7776718 0 1 fastDFS的DownloadStream,FileOutputStream 下载 download_file(group_name, remote_filename , downloadStream) 59113472(约58M) 499ms 118702 113.2030487 2K 1 fastDFS的DowloadStream,BufferedOutputStream 下载 download_file(group_name, remote_filename , DownloadCallback) 59113472(约59M) 592ms 99853 95.22724152 2K 1 实现DownloadCallback,BufferedOutputStream 下载建议:100M内数据使用fastDFS提供的DownloadStream;大于1G的数据,使用BufferedOutputStream和DowloadStream

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值