我正在尝试将HTML转换为PDF。我观看了本教程https://www.codingforentrepreneurs.com/blog/html-template-to-pdf-in-django/,并成功地使本教程可以使用硬编码值。问题是...我无法弄清楚如何动态地将我的模型及其属性合并到此示例中。
这是我遵循的步骤...
首先,我将具有以下版本的reportlab安装到我的环境中...
pip install --pre xhtml2pdf
这行得通...
然后,按照说明将utils.py文件添加到我的项目中。
然后我将此代码复制到utils.py文件中...
from io import BytesIO
from django.http import HttpResponse
from django.template.loader import get_template
from xhtml2pdf import pisa
def render_to_pdf(template_src, context_dict={}):
template = get_template(template_src)
html = template.render(context_dict)
result = BytesIO()
pdf = pisa.pisaDocument(BytesIO(html.encode("ISO-8859-1")), result)
if not pdf.err:
return HttpResponse(result.getvalue(), content_type='application/pdf')
return None
然后我创建了一个类似于以下内容的HTML文件:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<title>Title</title>
<style type="text/css">
body {
font-weight: 200;
font-size: 14px;
}
.header {
font-size: 20px;
font-weight: 100;
text-align: center;
color: #007cae;
}
.title {
font-size: 22px;
font-weight: 100;
/* text-align: right;*/
padding: 10px 20px 0px 20px;
}
.title span {
color: #007cae;
}
.details {
padding: 10px 20px 0px 20px;
text-align: left !important;
/*margin-left: 40%;*/
}
.hrItem {
border: none;
height: 1px;
/* Set the hr color */
color: #333; /* old IE */
background-color: #fff; /* Modern Browsers */
}
</style>
</head>
<body>
<div class='wrapper'>
<div class='header'>
<p class='title'>Invoice # </p>
</div>
<div>
<div class='details'>
Bill to: {{ customer_name }} <br/>
Amount: {{ amount }} <br/>
Date:
<hr class='hrItem' />
</div>
</div>
</body>
</html>
我还创建了必要的URL。...
然后我创建了一个类似于下面定义的视图:
from django.http import HttpResponse
from django.views.generic import View
from yourproject.utils import render_to_pdf #created in step 4
class GeneratePdf(View):
def get(self, request, *args, **kwargs):
data = {
'today': datetime.date.today(),
'amount': 39.99,
'customer_name': 'Cooper Mann',
'order_id': 1233434,
}
pdf = render_to_pdf('pdf/invoice.html', data)
return HttpResponse(pdf, content_type='application/pdf')
当我单击指向该视图的链接时,输出将如本教程中所述那样显示...
但是,如果我试图让我的模型以这种格式显示...我就很难做到这一点。我尝试了一个DetailView...。然后我得到了数据,但没有PDF ....我也搜索了许多其他地方,但似乎找不到一个可以动态获取模型并提取模型的示例。根据需要添加属性...在此先感谢您的帮助或指点。
答案 0 :(得分:3)
如果您想使用DetailView
,我想您可以这样做:
class SomeDetailView(DetailView):
model = YourModel
template_name = 'pdf/invoice.html'
def get_context_data(self, **kwargs):
context = super(SomeDetailView, self).get_context_data(**kwargs)
# add extra context if needed
return context
def render_to_response(self, context, **kwargs):
pdf = render_to_pdf(self.template_name, context)
return HttpResponse(pdf, content_type='application/pdf')
在这里,我覆盖render_to_response
以覆盖DetailView的默认响应以返回PDF响应。在这里,进入的上下文来自get_context_data
。在get_context_data
中,您可以根据需要添加任何其他上下文。