如何在Reportlab中引用模型

时间:2019-05-29 01:23:38

标签: python django reportlab

我的目标是使用ReportLab创建pdf报告,其中一些文本基于主键是动态的。

我有一个下拉列表,列出了程序中当前创建的每个主键(当前为#1-5),并且随着创建的“货件”越来越多,主键被添加到了下拉列表中。

当我选择主键然后单击“提交”按钮时,我希望pdf生成动态文本与该pk专门相关的位置。

下面是我目前使用静态文本(从reportlab的源中拉出)的PDF的视图,在该视图中,我希望根据所选的pk动态替换诸如“ JOHN DOE”和“ Name here here”的值

views.py

def write_pdf_view(request):
    response = HttpResponse(content_type='application/pdf')
    response['Content-Disposition'] = 'inline; filename="mypdf.pdf"'


    buffer = BytesIO()
    p = canvas.Canvas(buffer)

    # Start writing the PDF here
    p.setLineWidth(.3)
    p.setFont('Helvetica', 12)


    p.drawString(30,750,'Name goes here') 
    p.drawString(30,735,'OF ACME INDUSTRIES')
    p.drawString(500,750,"12/12/2010")
    p.line(480,747,580,747)

    p.drawString(275,725,'AMOUNT OWED:')
    p.drawString(500,725,"$1,000.00")
    p.line(378,723,580,723)

    p.drawString(30,703,'RECEIVED BY:')
    p.line(120,700,580,700)
    p.drawString(120,703,"JOHN DOE")
    # End writing

    p.showPage()
    p.save()

    pdf = buffer.getvalue()
    buffer.close()
    response.write(pdf)

    return response

这是正在创建的下拉列表

ViEWS.py

def reference_view(request):
    query_results = Orders.objects.all()
    reference_list = DropDownMenuReferences()

    context = {
        'query_results': query_results,
        'reference_list': reference_list
    }
    return render(request, 'proforma_select.html', context)

Forms.py

class DropDownMenuReferences(forms.Form):
    Reference_IDs = forms.ModelChoiceField(queryset=Orders.objects.values_list('reference', flat=True).distinct(),
    empty_label=None)

模板

{% extends 'base.html' %}

{% block body %}

<div class="container">

  <br>

  <form method=POST action="">
    {{ reference_list }}

    <button type="submit" class="btn btn-primary" name="button">Add Order</button>
  </form>

</div>

{% endblock %}

我目前完全不确定如何解决此问题。我有下拉菜单,而且我了解如何创建pdf文件,但我不知道将它们绑在一起的位置。

1 个答案:

答案 0 :(得分:0)

您可以在程序的窗体区域中包括所需人员的相关主键。当用户单击“提交”按钮时,该主键将包含在您的request对象中。

然后在您的write_pdf_view函数中,可以通过以下方式从数据库中提取相关人员:

def write_pdf_view(request):

    if request.method == 'POST':
        primary_key = request.POST.get('primary_key')
        person = models.Person.objects.get(pk=primary_key)

        ...

        p.drawString(120, 703, person.full_name)

    ...

    return response