Объект XlsxWriter сохранить как http-ответ для создания загрузки в Django
объект XlsxWriter сохранить как http-ответ для создания загрузки в Django?
3 ответов
Я думаю, вы спрашиваете о том, как создать файл excel в памяти с помощью xlsxwriter
и верните его через HttpResponse
. Вот пример:
try:
import cStringIO as StringIO
except ImportError:
import StringIO
from django.http import HttpResponse
from xlsxwriter.workbook import Workbook
def your_view(request):
# your view logic here
# create a workbook in memory
output = StringIO.StringIO()
book = Workbook(output)
sheet = book.add_worksheet('test')
sheet.write(0, 0, 'Hello, world!')
book.close()
# construct response
output.seek(0)
response = HttpResponse(output.read(), mimetype="application/vnd.openxmlformats-officedocument.spreadsheetml.sheet")
response['Content-Disposition'] = "attachment; filename=test.xlsx"
return response
надеюсь, что это поможет.
небольшое обновление ответа @alecxe для Python 3 (io.BytesIO вместо StringIO.StringIO) и Django >= 1.5 (content_type вместо 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
когда дело доходит до Джанго, вы даже можете обойтись без целого StringIO
проделки. HttpResponse
ведет себя так же, как StringIO в этом отношении:
from django.http import HttpResponse
from xlsxwriter.workbook import Workbook
def your_view(request):
# your view logic here
# create the HttpResponse object ...
response = HttpResponse(content_type='application/vnd.openxmlformats-officedocument.spreadsheetml.sheet')
response['Content-Disposition'] = "attachment; filename=test.xlsx"
# .. and pass it into the XLSXWriter
book = Workbook(response, {'in_memory': True})
sheet = book.add_worksheet('test')
sheet.write(0, 0, 'Hello, world!')
book.close()
return response
добавление: вам нужно указать {'in_memory': True}
или вы могли бы сделать HttpResponse has no attribute seek()
. Спасибо @Jeb