0

我在将 html 文件中的图像导出为 pdf 时遇到问题,此处存在类似的解决方案。

html 正在服务器上正确呈现。我通过在 url 上交叉检查来验证它。

但是在尝试下载/渲染pdf时**我得到一个pdf但它是空白的,它还在views.py中下载功能的第三行显示错误

这是我尝试过的:

.html 文件:

<html>
<head>
<link href="{{ STATIC_URL }}css/certificate.css" rel="stylesheet"
  type="text/css" />
</head> 
<body>
<div class="certificate_container">
    <div class="statictext">
        <p>{{ name }}</p>
    </div>
</div>
</body>
<html>

css 文件:

body{margin:0px; padding:0px;}
.certificate_container{ width:792px; height:612px; background:url("../images/certificate.gif") no-repeat;}
.statictext{width:400px; margin:0px auto; padding-top:240px; height:30px; text-align:center; font:bold 14px Arial, Helvetica, sans-serif; color:#333;}

视图.py:

#relevant imports
from reportlab.pdfgen import canvas
import xhtml2pdf.pisa as pisa
import cStringIO as StringIO

def download(request):
    html = render_to_string("certificate.html", { 'pagesize' : 'A4', }, context_instance=RequestContext(request))
    result = StringIO.StringIO()
    pdf = pisa.pisaDocument(StringIO.StringIO(), dest=result, link_callback=fetch_resources )
    if not pdf.err:
        return HttpResponse(result.getvalue(), mimetype='application/pdf')
    return HttpResponse('Gremlins ate your pdf! %s' % cgi.escape(html))

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


def home(request):
    return render(request, 'certificate.html', {'name':'user1'} )

网址已得到妥善处理。

4

1 回答 1

0

后来我发现,使用上述技术堆栈无法实现这一点,因此我尝试获取模板图像并使用 PIL 根据上下文对其进行修改。这奏效了。

于 2012-03-07T02:32:16.373 回答