我的目标是使用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文件,但我不知道将它们绑在一起的位置。
答案 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