Ответ 1
Разница между 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'),
)
Открытие pdf/в вашем браузере начнет загрузку my_pdf.pdf на основе my_template.html, my_header_template.html и my_footer_template.html.
В расширенном примере показано, как подкласс PDFTemplateView расширяет и меняет логику PDFTemplateView. Чтобы понять, что происходит, прочитайте Использование представлений на основе классов.
Подобно header_template
и footer_template
, вы можете определить response_class
. Поскольку PDFTemplateResponse является значением по умолчанию, вам не нужно его определять.
ИЗМЕНИТЬ
Следующее простое представление предоставляет вам pdf вместо html. Это не используется django-wkhtmltopdf. Вы можете использовать wkhtmltopdf в своей функции html2pdf.
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
РЕДАКТИРОВАТЬ 2
Простой вид с контекстом:
template.html
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>Untitled</title>
</head>
<body>
<h1>{{ title }}</h1>
</body>
</html>
urls.py
from views import MyPDFView
urlpatterns = patterns('',
(r'^pdf/', MyPDFView.as_view()),
)
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
РЕДАКТИРОВАТЬ 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