Django对象和openpyxl单元。如何设置像django对象字段的值这样的单元格值?

时间:2019-06-19 04:00:29

标签: python django openpyxl

我必须编写一个代码块,以便从Django数据集(少数模型)生成xlsx报告。报告的框架比通常的x行y列具有更困难的结构(某些单元格已合并)。它看起来应该像这样: enter image description here

所以我写了视图函数:

from cut.models import *
from django.http import HttpResponse
from openpyxl.workbook import Workbook
from openpyxl.styles import PatternFill, Border, Side, Alignment, Protection, Font

def get_report(request):

    rent_test = Renters.objects.all

    response = HttpResponse(
        content_type='application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',
    )
    response['Content-Disposition'] = 'attachment; filename=FORM_1-IL.xlsx'.format()
    workbook = Workbook()

    worksheet = workbook.active
    worksheet.title = 'A_REPORT'

    worksheet.merge_cells('A2:A5')
#...
    worksheet.merge_cells('M4:M5')

    worksheet['A2'].value = 'name of forestry'
#...etc.
    columns = [
    'only_one_column'
    ]
    row_num = 1

    for col_num, column_title in enumerate(columns, 1):
        cell = worksheet.cell(row=row_num, column=col_num)
        cell.value = column_title


    workbook.save(response)

    return response

所有这些都是可以理解和简单的。 但是我如何使用django字段呢?我希望将它们转移到相对单元格(字段值,而不是红色字体“字段值”

0 个答案:

没有答案