【Python】Fastapi 使用 Pandas 实现导出 Excel
除了 pandas ,使用 xlsxwriter或openpyxl 应该也可以,基本相同.
笔记 备忘 便于 后续查阅使用
背景
在使用 Fastapi ,且使用到了大量 pandas 时,遇到浏览器导出Excel的需求时.
使用场景
- 导出待导入模板.
- 导出报表
- 导出明细 等…
一 . 提取的利于复用的方式
思路
- 提取 为公共方法到 公共方法中.
- 便于 多个接口中 复用.
示例代码
from fastapi import APIRouter
from fastapi.responses import StreamingResponse
import pandas as pd
import io
router = APIRouter(prefix="/api/导入")
def df_downxlsx(df: pd.DataFrame, filename: str = 'out.xlsx') -> StreamingResponse:
# 创建 IO buffer
buffer = io.BytesIO()
# 将df写入buffer
df.to_excel(buffer, index=False)
buffer.seek(0)
excel_bytes = buffer.getvalue()
headers = {
"Content-Disposition": f"attachment; filename={filename}".encode("utf-8").decode("latin1")}
media_type = "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"
return StreamingResponse(io.BytesIO(excel_bytes), media_type=media_type, headers=headers)
@router.get("/down_template", tags=['导入'], name="下载导入模板")
async def api_down_template(template: str):
# 表头字段
columns = ['姓名', '学号', '班级']
# 表格内容,模板时:可以为空,或表格内容. 其他表格时正常内容即可.
# data = []
data = [{'姓名': 'xx', '学号': 'xx', '班级': 'xx'}]
# 创建 DataFrame
df = pd.DataFrame(data, columns=columns)
filename = '导入模板.xlsx'
return df_downxlsx(df, filename)
二 . 单个简单接口的方式
以导出 导入模板 为例
有时在 上传页面,会有导入的需求,但导入的模板 通常会和使用方协商好,避免操作者 导入的表格不规范,通常会 提供下载模板的方式 规范上传的表格.
示例代码
from fastapi import APIRouter
from fastapi.responses import StreamingResponse
import pandas as pd
import io
router = APIRouter(prefix="/api/导入")
@router.get("/down_template", tags=['导入'], name="下载导入模板")
async def down_template(template: str):
# 表头字段
columns = ['姓名', '学号', '班级']
# 表格内容,模板时:可以为空,或表格内容. 其他表格时正常内容即可.
# data = []
data = [{'姓名': 'xx', '学号': 'xx', '班级': 'xx'}]
# 创建 DataFrame
df = pd.DataFrame(data, columns=columns)
# 创建 IO buffer
buffer = io.BytesIO()
# 将df写入buffer
df.to_excel(buffer, index=False)
buffer.seek(0)
excel_bytes = buffer.getvalue()
filename = '导入模板.xlsx'
headers = {
"Content-Disposition": f"attachment; filename={filename}".encode("utf-8").decode("latin1")}
media_type = "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"
return StreamingResponse(io.BytesIO(excel_bytes), media_type=media_type, headers=headers)
三. TODO 单文件 可直接测试的文件
# TODO 单文件 可直接测试的文件
其他参考:
路漫漫其修远兮,吾将上下而求索.