41

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

4

5 に答える 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 (パッケージ開発者)の公式ドキュメントに従うことをお勧めします。

例: シンプルな Django クラス

于 2021-04-19T15:44:09.023 に答える