web-dev-qa-db-ja.com

XlsxWriterオブジェクトをhttp応答として保存して、Django

XlsxWriterオブジェクトはhttp応答として保存してDjangoでダウンロードを作成しますか?

34
Waheed Ahmed

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

お役に立てば幸いです。

53
alecxe

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
62
Jeb

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

16
nuts