Представьте HTML к PDF в сайте Django

Я не думаю, что это имеет много значения для вектора. Я предпочитаю использовать индекс сам, поскольку я полагаю, что он более читаем, и можно сделать произвольный доступ как переходящий вперед 6 объектов или переходящий назад если потребности быть.

мне также нравится делать ссылку на объект в цикле как это, таким образом, нет большого количества квадратных скобок вокруг места:

for(size_t i = 0; i < myvector.size(); i++)
{
    MyClass &item = myvector[i];

    // Do stuff to "item".
}

Используя итератор может быть хорошим, если Вы думаете, что, возможно, должны были бы заменить вектор списком в какой-то момент в будущем, и это также выглядит более стильным к пятнам STL, но я не могу думать ни о какой другой причине.

111
задан Olli 3 February 2014 в 14:14
поделиться

1 ответ

Попробуйте решение из Reportlab .

Загрузите и установите его, как обычно, с помощью python setup.py install

Вам также потребуется установить следующие модули : xhtml2pdf, html5lib, pypdf с easy_install.

Вот пример использования:

Сначала определите эту функцию:

import cStringIO as StringIO
from xhtml2pdf import pisa
from django.template.loader import get_template
from django.template import Context
from django.http import HttpResponse
from cgi import escape


def render_to_pdf(template_src, context_dict):
    template = get_template(template_src)
    context = Context(context_dict)
    html  = template.render(context)
    result = StringIO.StringIO()

    pdf = pisa.pisaDocument(StringIO.StringIO(html.encode("ISO-8859-1")), result)
    if not pdf.err:
        return HttpResponse(result.getvalue(), content_type='application/pdf')
    return HttpResponse('We had some errors<pre>%s</pre>' % escape(html))

Затем вы можете использовать ее так:

def myview(request):
    #Retrieve data or whatever you need
    return render_to_pdf(
            'mytemplate.html',
            {
                'pagesize':'A4',
                'mylist': results,
            }
        )

Шаблон:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
    <head>
        <title>My Title</title>
        <style type="text/css">
            @page {
                size: {{ pagesize }};
                margin: 1cm;
                @frame footer {
                    -pdf-frame-content: footerContent;
                    bottom: 0cm;
                    margin-left: 9cm;
                    margin-right: 9cm;
                    height: 1cm;
                }
            }
        </style>
    </head>
    <body>
        <div>
            {% for item in mylist %}
                RENDER MY CONTENT
            {% endfor %}
        </div>
        <div id="footerContent">
            {%block page_foot%}
                Page <pdf:pagenumber>
            {%endblock%}
        </div>
    </body>
</html>

Надеюсь, это поможет.

202
ответ дан 24 November 2019 в 03:00
поделиться
Другие вопросы по тегам:

Похожие вопросы: