XlsxWriterオブジェクトはhttp応答として保存してDjangoでダウンロードを作成しますか?
xlsxwriter
を使用してメモリ内にExcelファイルを作成し、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
お役に立てば幸いです。
Python 3(io.BytesIOの代わりにStringIO.StringIO)およびDjango> = 1.5(mimetypeの代わりにcontent_type)、@ 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
Djangoに関しては、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