django将数据库数据以excel返回前端下载

开发过程中需要根据前端请求到数据库中查询符合条件数据,然后组织数据返回给浏览器下载,网上找到的django提供下载文件功能多以读取服务器已存在文件再返回给用户,本次需求服务器没有该文件,同时也不想生成该临时文件。

1、假设已读取数据库数据如下所示:

import pymysql
conn = pymysql.connection(**config)
cursor = conn.cursor()
cursor.execute("select id, name, age from user;")
# 假设得到数据如下
ret = [[1, 'tom', 2],[2, 'jerry', 1]]
import pandas as pd
df = pd.DataFrame(ret, columns=['id', 'name', 'age'])

# 利用pandas将数据存入excel文件中
from io import BytesIO
bio = BytesIO()
writer = pd.ExcelWriter(bio, engine='xlsxwriter')  # 注意安装这个包 pip install xlsxwriter
df.to_excel(writer, sheet_name='Sheet1')
writer.save()
bio.seek(0)
# bio.read() 不要read出来,否则seek就到文件最后了,导致下载的是空文件
# 至此,数据已写入bio中
from django.http import FileResponse
response = FileResponse(bio)
response['Content-Type'] = 'application/octet-stream'
response['Content-Disposition'] = 'attachment;filename="mm.xlsx"'
return response

参考:https://pandas.pydata.org/pandas-docs/stable/user_guide/io.html#writing-excel-files-to-memory

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值