pdfkit页眉和页脚

2024-04-20 08:47:10 发布

您现在位置:Python中文网/ 问答频道 /正文

我一直在网上搜索人们在实现页眉和页脚时使用pdfkit(python包装器)的例子,但找不到任何例子。
是否有人能够展示一些如何使用pdfkit python包装器在wkhtmltoppdf中实现选项的示例?


Tags: 示例选项例子页脚pdfkit页眉wkhtmltoppdf
3条回答

改进@V Stoykov answer,因为它帮助我使用烧瓶,在烧瓶中使用自定义标题的渲染函数如下:

import os
import tempfile

import pdfkit
from flask import render_template, make_response


@app.route('/generate_pdf')
def render_pdf_custom_header(foo, bar):
    main_content = render_template('main_pdf.html', foo=foo)
    options = {
        '--encoding': "utf-8"
    }

    add_pdf_header(options, bar)
    add_pdf_footer(options)

    try:
        pdf = pdfkit.from_string(main_content, False, options=options)
    finally:
        os.remove(options['--header-html'])
        os.remove(options['--footer-html'])

    response = build_response(pdf)
    return response

def add_pdf_header(options, bar):
    with tempfile.NamedTemporaryFile(suffix='.html', delete=False) as header:
        options['--header-html'] = header.name
        header.write(
            render_template('header.html', bar=bar).encode('utf-8')
        )
    return

def add_pdf_footer(options):
    # same behaviour as add_pdf_header but without passing any variable
    return

def build_response(pdf):
    response = make_response(pdf)
    response.headers['Content-Type'] = 'application/pdf'
    filename = 'pdf-from-html.pdf'
    response.headers['Content-Disposition'] = ('attachment; filename=' + filename)
    return response

注意,我使用了'--header-html''--footer-html'符号,因为它与wkhtmltopf的选项格式匹配。

我只对页眉使用它,但我认为对页脚也一样。

头部需要有单独的html文件。

header.html标题

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
</head>
<body>

    Code of your header goes here.

</body>
</html>

然后你可以在Python中这样使用它

import pdfkit

pdfkit.from_file('path/to/your/file.html', 'out.pdf', {
    '--header-html': 'path/to/header.html'
})

如果您使用像Django这样的后端并希望使用模板,那么棘手的部分是您不能将头html作为呈现字符串传递。你需要一个文件。

这就是我用Django渲染pdf的方法。

import os
import tempfile
import pdfkit

from django.template.loader import render_to_string


def render_pdf(template, context, output, header_template=None):
    """
    Simple function for easy printing of pdfs from django templates

    Header template can also be set
    """
    html = render_to_string(template, context)
    options = {
        '--load-error-handling': 'skip',
    }
    try:
        if header_template:
            with tempfile.NamedTemporaryFile(suffix='.html', delete=False) as header_html:
                options['header-html'] = header_html.name
                header_html.write(render_to_string(header_template, context).encode('utf-8'))

        return pdfkit.from_string(html, output, options=options)
    finally:
        # Ensure temporary file is deleted after finishing work
        if header_template:
            os.remove(options['header-html'])

在我的示例中,我创建了放置呈现内容的临时文件。重要的一点是,临时文件需要以.html结尾并手动删除。

options = {
'page-size': 'Letter',
'margin-top': '0.9in',
'margin-right': '0.9in',
'margin-bottom': '0.9in',
'margin-left': '0.9in',
'encoding': "UTF-8",
'header-center': 'YOUR HEADER',
'custom-header' : [
    ('Accept-Encoding', 'gzip')
],
'no-outline':None
}

您可以在header-center的值中添加头

相关问题 更多 >