Sev*_*ths 12 django wkhtmltopdf
可能有人请我提供的如何获得一个完整的例子view在django一个返回PDF使用wkhtmltopdf.附带的示例数量有限,django-wkhtmltopdf并且它们假定我没有的知识水平.我查看了源代码,但我无法做出如何使用它的正面或反面(例如,PDFTemplateView和PDFTemplateResponse?之间的差异?!?)
我会非常感谢任何帮助.
BTW(我也使用页眉和页脚的模板)
编辑
def some_view(request,sID):
something = get_object_or_404(Something,id=sID)
return render_to_response('something.html', {'something':something}, context_instance=RequestContext(request))
Run Code Online (Sandbox Code Playgroud)
我如何获得以下简单视图来为我提供pdf而不是html文件?
编辑2
我目前正在玩:
def pdf_view(request,sID):
template = 'pdf.html'
something = get_object_or_404(Something,id=sID)
context = {
'something' : Something,
'object_for_header_and_footer': something.object_for_header_and_footer,
}
cmd_options = settings.WKHTMLTOPDF_CMD_OPTIONS
return PDFTemplateResponse(request=request,
context=context,
template=template,
filename='something',
header_template='header.html',
footer_template='footer.html',
cmd_options=cmd_options)
Run Code Online (Sandbox Code Playgroud)
但我'str' object has no attribute 'update'进去了/usr/local/lib/python2.7/dist-packages/wkhtmltopdf/utils.py in wkhtmltopdf, line 74.我不知道是否要开始攻击wkhtmltopdf?!?!
all*_*aps 22
PDFTemplateView和PDFTemplateResponse之间的区别在于视图是基于类的视图.并且PDFTemplateResponse呈现pdf数据并设置正确的响应头.要添加页眉和页脚:
# urls.py
from django.conf.urls.defaults import *
from wkhtmltopdf.views import PDFTemplateView
urlpatterns = patterns('',
...
url(r'^pdf/$', PDFTemplateView.as_view(template_name='my_template.html',
filename='my_pdf.pdf',
header_template='my_header_template.html',
footer_template='my_footer_template.html',
...
), name='pdf'),
)
Run Code Online (Sandbox Code Playgroud)
在浏览器中打开pdf /将根据my_template.html,my_header_template.html和my_footer_template.html开始下载my_pdf.pdf.
的先进例子示出了如何继承PDFTemplateView延伸并改变PDFTemplateView的逻辑.要了解什么情况发生读取使用基于类的观点.
喜欢header_template和footer_template你可以定义一个response_class.由于PDFTemplateResponse是默认值,因此您无需定义它.
编辑
以下简单视图为您提供了pdf而不是html.这不是使用django-wkhtmltopdf.您可以在html2pdf函数中使用wkhtmltopdf.
def some_view(request):
t = loader.get_template('myapp/template.html')
c = RequestContext(request, {'foo': 'bar'})
html = t.render(c)
pdf_data = html2pdf(html) # Your favorite html2pdf generator
response = HttpResponse(pdf_data, content_type='application/pdf')
response['Content-Disposition'] = 'attachment; filename="some_filename.pdf"'
return response
Run Code Online (Sandbox Code Playgroud)
编辑2
上下文的简单视图:
template.html
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>Untitled</title>
</head>
<body>
<h1>{{ title }}</h1>
</body>
</html>
Run Code Online (Sandbox Code Playgroud)
urls.py
from views import MyPDFView
urlpatterns = patterns('',
(r'^pdf/', MyPDFView.as_view()),
)
Run Code Online (Sandbox Code Playgroud)
views.py
from django.views.generic.base import View
from wkhtmltopdf.views import PDFTemplateResponse
class MyPDFView(View):
template='template.html'
context= {'title': 'Hello World!'}
def get(self, request):
response = PDFTemplateResponse(request=request,
template=self.template,
filename="hello.pdf",
context= self.context,
show_content_in_browser=False,
cmd_options={'margin-top': 50,},
)
return response
Run Code Online (Sandbox Code Playgroud)
编辑3
如果使用DetailView,则可以将对象添加到上下文中:
url(r'^books/(?P<pk>\d+)/$', MyPDFView.as_view(), name='book-detail'),
class MyPDFView(DetailView):
template='pdftestapp/template.html'
context= {'title': 'Hello World!'}
model = Book
def get(self, request, *args, **kwargs):
self.context['book'] = self.get_object()
response=PDFTemplateResponse(request=request,
template=self.template,
filename ="hello.pdf",
context=self.context,
show_content_in_browser=False,
cmd_options={'margin-top': 50,}
)
return response
Run Code Online (Sandbox Code Playgroud)