Подтвердить что ты не робот

Объект XlsxWriter сохраняет как HTTP-ответ для создания загрузки в Django

Объект XlsxWriter сохраняет как HTTP-ответ для создания загрузки в Django?

4b9b3361

Ответ 1

Я думаю, вы спрашиваете о том, как создать файл 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

Надеюсь, что это поможет.

Ответ 2

Небольшое обновление для ответа @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

Ответ 3

Когда дело доходит до Django, вы можете обойтись без целых StringIO shenanigans. 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