0

htmlファイルの画像をpdfとしてエクスポートするのに問題がありました。同様の解決策がここにあります

htmlはサーバー上で適切にレンダリングされています。URLでクロスチェックして確認しました。

しかし、PDFをダウンロード/レンダリングしようとすると** PDFが表示されますが、これは空白です。また、views.pyのダウンロード関数の3行目にエラーが表示されます。

これが私が試したことです:

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;}

views.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'} )

URLは適切に処理されています。

4

1 に答える 1

0

後で、上記の技術スタックを使用してこれを実現できないことがわかりました。そのため、テンプレートイメージを取得し、PILを使用してコンテキストに基づいて変更しようとしました。そしてそれはうまくいった。

于 2012-03-07T02:32:16.373 に答える