通过flowable将现有PDF合并到新的ReportLab PDF中

kyl*_*ner 7 python pdf django pdf-generation reportlab

我有一个reportlab SimpleDocTemplate并将其作为动态PDF返回.我基于一些Django模型元数据生成它的内容.这是我的模板设置:

buff = StringIO()
doc = SimpleDocTemplate(buff, pagesize=letter,
                        rightMargin=72,leftMargin=72,
                        topMargin=72,bottomMargin=18)
Story = []
Run Code Online (Sandbox Code Playgroud)

我可以轻松地将Entry模型中的文本元数据添加Story到稍后要构建的列表中:

    ptext = '<font size=20>%s</font>' % entry.title.title()
    paragraph = Paragraph(ptext, custom_styles["Custom"])
    Story.append(paragraph)
Run Code Online (Sandbox Code Playgroud)

然后通过调用以下build内容生成要在响应中返回的PDF 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
Run Code Online (Sandbox Code Playgroud)

模型上的一个元数据字段是文件附件.当这些文件附件是PDF时,我想将它们合并到我正在生成的故事中; IE表示reportlab"flowable"类型的PDF.

我试图这样做pdfrw,但没有运气.理想情况下,我很乐意打电话:

from pdfrw import PdfReader
pdf = pPdfReader(entry.document.file.path)
Story.append(pdf)
Run Code Online (Sandbox Code Playgroud)

并将pdf附加到现有的故事列表中,以包含在最终文档的生成中,如上所述.

有人有主意吗?我尝试使用pagexobj创建类似的东西,尝试按照这个例子:

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))
Run Code Online (Sandbox Code Playgroud)

但也没有任何运气.有人可以向我解释将现有PDF文件合并到reportlab可流动的最佳方法吗?我对这些东西并不擅长,并且几天来一直在敲打pdf一代.:)任何方向非常感谢!

Rya*_*ady 3

我刚刚在一个项目中完成了类似的任务。我使用reportlab(开源版本)生成pdf文件和pyPDF以方便合并。我的要求略有不同,因为我只需要每个附件的一页,但我确信这可能足以让您了解总体想法。

from pyPdf import PdfFileReader, PdfFileWriter

def create_merged_pdf(user):
    basepath = settings.MEDIA_ROOT + "/"
    # following block calls the function that uses reportlab to generate a pdf
    coversheet_path = basepath + "%s_%s_cover_%s.pdf" %(user.first_name, user.last_name, datetime.now().strftime("%f"))
    create_cover_sheet(coversheet_path, user, user.performancereview_set.all())

    # now user the cover sheet and all of the performance reviews to create a merged pdf
    merged_path = basepath + "%s_%s_merged_%s.pdf" %(user.first_name, user.last_name, datetime.now().strftime("%f"))

    # for merged file result
    output = PdfFileWriter()

    # for each pdf file to add, open in a PdfFileReader object and add page to output
    cover_pdf = PdfFileReader(file( coversheet_path, "rb"))
    output.addPage(cover_pdf.getPage(0))

    # iterate through attached files and merge.  I only needed the first page, YMMV
    for review in user.performancereview_set.all():
        review_pdf = PdfFileReader(file(review.pdf_file.file.name, "rb"))
        output.addPage(review_pdf.getPage(0)) # only first page of attachment

    # write out the merged file
    outputStream = file(merged_path, "wb")
    output.write(outputStream)
    outputStream.close()
Run Code Online (Sandbox Code Playgroud)