Я использую Django, и мой код для рендеринга PDF действительно типичен:
t = loader.get_template('back/templates/content/receipt.html')
c = RequestContext(request, {
'pagesize': 'A4',
'invoice': invoice,
'plan': plan,
})
html = t.render(c)
result = StringIO.StringIO()
pdf = pisa.pisaDocument(StringIO.StringIO(html.encode("UTF-8")), result)
if not pdf.err:
return HttpResponse(result.getvalue(), mimetype="application/pdf")
И в квитанции.html нет ничего необычного:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<title>Squizzal Receipt</title>
<style type="text/css">
@page {
size: {{pagesize}};
margin: 1cm;
word-spacing 1cm;
@frame footer {
-pdf-frame-content: footerContent;
bottom: 0cm;
margin-left: 9cm;
margin-right: 9cm;
height: 1cm;
}
}
</style>
</head>
<body>
<h1>Your Receipt</h1>
<<SNIP>>
но ни одно из мест в pdf не отображается. Все слова находятся рядом друг с другом. Я пробовал нормальные пробелы и "& nbsp", и результат тот же. Например, приведенное выше будет отображаться как "YourReceipt" в PDF.
Когда я пытаюсь использовать версию pisa для командной строки, она просто генерирует pdf с пробелами между словами.
Есть мысли?