开发过程中需要根据前端请求到数据库中查询符合条件数据,然后组织数据返回给浏览器下载,网上找到的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