XlsxWriter 对象另存为 http 响应以在 Django 中创建下载?
最佳答案
对 Python 3(io.BytesIO 而不是 StringIO.StringIO)和 Django >= 1.5(content_type 的 @alecxe 响应的一点更新> 而不是 mimetype),具有完全在内存中的文件程序集,该程序集已由 @jmcnamara ({'in_memory': True}) 实现!
这是完整的例子:
import io
from django.http.response import HttpResponse
from xlsxwriter.workbook import Workbook
def your_view(request):
output = io.BytesIO()
workbook = Workbook(output, {'in_memory': True})
worksheet = workbook.add_worksheet()
worksheet.write(0, 0, 'Hello, world!')
workbook.close()
output.seek(0)
response = HttpResponse(output.read(), content_type="application/vnd.openxmlformats-officedocument.spreadsheetml.sheet")
response['Content-Disposition'] = "attachment; filename=test.xlsx"
output.close()
return response
关于python - XlsxWriter 对象另存为 http 响应以在 Django 中创建下载,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16393242/