reportlab がSimpleDocTemplate
あり、動的 PDF として返します。Django モデルのメタデータに基づいてコンテンツを生成しています。これが私のテンプレートのセットアップです:
buff = StringIO()
doc = SimpleDocTemplate(buff, pagesize=letter,
rightMargin=72,leftMargin=72,
topMargin=72,bottomMargin=18)
Story = []
Entry
モデルのテキスト メタデータをリストに簡単に追加して、Story
後でビルドすることができます。
ptext = '<font size=20>%s</font>' % entry.title.title()
paragraph = Paragraph(ptext, custom_styles["Custom"])
Story.append(paragraph)
次に、 を呼び出して、応答で返される PDF を生成しbuild
ますSimpleDocTemplate
。
doc.build(Story, onFirstPage=entry_page_template, onLaterPages=entry_page_template)
pdf = buff.getvalue()
resp = HttpResponse(mimetype='application/x-download')
resp['Content-Disposition'] = 'attachment;filename=logbook.pdf'
resp.write(pdf)
return resp
モデルの 1 つのメタデータ フィールドは添付ファイルです。それらの添付ファイルが PDF の場合、生成しているストーリーにそれらをマージしたいと思います。reportlab の「フロー可能」タイプの PDF を意味する IE。
を使用してそうしようとしてpdfrw
いますが、運がありません。理想的には、次のように呼び出したいと思います:
from pdfrw import PdfReader
pdf = pPdfReader(entry.document.file.path)
Story.append(pdf)
上記のように、PDF を既存のストーリー リストに追加して、最終ドキュメントの生成に含めます。
誰にもアイデアはありますか?pagexobj を使用してpdfを作成し、次の例に従ってみました:
http://code.google.com/p/pdfrw/source/browse/trunk/examples/rl1/subset.py
from pdfrw.buildxobj import pagexobj
from pdfrw.toreportlab import makerl
pdf = pagexobj(PdfReader(entry.document.file.path))
しかし、運もありませんでした。既存の PDF ファイルを reportlab フローアブルにマージする最良の方法を誰かに説明してもらえますか? 私はこのようなことが苦手で、何日もの間、pdf生成に頭を悩ませてきました。:) どの方向も大歓迎です!