“一台打印机配有一台精美的打印机和/或Acrobat的完整副本,可以轻松地将您的小PDF转换成小册子(例如,在一张11英寸x 17英寸的单张纸上打印4张字母大小的页面)。在
但这需要考虑几个因素,包括人员知道如何操作硬件和软件。小册子.py您可以将您的PDF转换为预先格式化的小册子,以减少他们弄乱的机会:“
我能告诉你的最好步骤是:函数开始在页面中循环
声明了一个变量“shift_right”是否会???(我想是为了元数据?)在
声明了一个只对元数据有用的变量“stuff”(我想)
x由BBox列表的第三个索引递增(这个列表是什么,它是什么时候建立的?)在
y被分配给y和Bbox列表的第三个索引之间的较大值(同样,这个列表指的是什么?)在
我想我的核心困惑是关于这两行与BBox,以及它们如何相互作用来创建一个11x17小册子PDF。谢谢你能帮我解决这个问题。在import sys
import os
import find_pdfrw
from pdfrw import PdfReader, PdfWriter, PdfDict, PdfArray, PdfName, IndirectPdfDict
from pdfrw.buildxobj import pagexobj
def fixpage(*pages):
pages = [pagexobj(x) for x in pages]
class PageStuff(tuple):
pass
x = y = 0
for i, page in enumerate(pages):
index = '/P%s' % i
shift_right = x and '1 0 0 1 %s 0 cm ' % x or ''
stuff = PageStuff((index, page))
stuff.stream = 'q %s%s Do Q\n' % (shift_right, index)
x += page.BBox[2]
y = max(y, page.BBox[3])
pages[i] = stuff
# Multiple copies of first page used as a placeholder to
# get blank page on back.
for p1, p2 in zip(pages, pages[1:]):
if p1[1] is p2[1]:
pages.remove(p1)
return IndirectPdfDict(
Type = PdfName.Page,
Contents = PdfDict(stream=''.join(page.stream for page in pages)),
MediaBox = PdfArray([0, 0, x, y]),
Resources = PdfDict(
XObject = PdfDict(pages),
),
)
inpfn, = sys.argv[1:]
outfn = 'booklet.' + os.path.basename(inpfn)
pages = PdfReader(inpfn).pages
# Use page1 as a marker to print a blank at the end
if len(pages) & 1:
pages.append(pages[0])
bigpages = []
while len(pages) > 2:
bigpages.append(fixpage(pages.pop(), pages.pop(0)))
bigpages.append(fixpage(pages.pop(0), pages.pop()))
bigpages += pages
PdfWriter().addpages(bigpages).write(outfn)