5

首先,我已经看到了有关此问题的其他线程,并且我尝试了几乎所有方法来尝试解决此问题,但是...

当使用 Pisa 将 HTML 页面呈现为 PDF 时,所述 HTML 中的图像明显丢失。也就是说,当页面呈现为 HTML 时,一切都只是花花公子,但是当我使用 Pisa 将输出切换为 PDF 时,图像消失了。

我发现做的最常见的事情是创建一个链接回调函数:

def fetch_resources(uri, rel):
    path = os.path.join(settings.MEDIA_ROOT, uri.replace(settings.MEDIA_URL, ""))
    return path

def my_view(request, variable1):
    html = render_to_string('template_goes_here.html', dict, context_instance=RequestContext(request))
    result = StringIO()
    pdf = pisa.pisaDocument(StringIO(html.encode("UTF-8")), dest=result, link_callback=fetch_resources)
    if not pdf.err:
        return HttpResponse(result.getvalue(), mimetype='application/pdf')
    return HttpResponse('Pisa hates you! %s' % cgi.escape(html))

但是,这不起作用。PDF 出现了,很好,但是没有图像。

我还在另一个线程上阅读了关于将 HTML 写入 mkstemp,通过命令行将其转换为 PDF,然后输出 HTML 的建议,但也没有成功。

我什至尝试安装 PIL 1.1.16 而不是 1.1.17,因为有人有类似的问题——没有骰子。

有人知道我在这里哪里出错了吗?

4

2 回答 2

3

自从我看这个已经有一段时间了,但我认为你必须使用 lambda 或 functools。

例如

links = lambda uri, rel: os.path.join(settings.MEDIA_ROOT, 
    uri.replace(settings.MEDIA_URL, ''))


pdf = pisa.pisaDocument(StringIO(html.encode("UTF-8")),
    dest=result, link_callback=links)
于 2012-03-19T22:41:27.993 回答
0

我认为这可能会有所帮助。在我的案例中,Windows 使用斜线是罪魁祸首。https://stackoverflow.com/a/12644633/1236599

于 2012-10-12T18:51:29.043 回答