XlsxWriterオブジェクトは、Djangoでダウンロードを作成するためにhttp応答として保存しますか?
29282 次
5 に答える
82
@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
于 2014-12-10T16:20:00.287 に答える
63
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
それが役立つことを願っています。
于 2013-05-16T20:19:31.283 に答える
1
jmcnamara (パッケージ開発者)の公式ドキュメントに従うことをお勧めします。
于 2021-04-19T15:44:09.023 に答える