У меня есть файл PDF, который был сделан в формате буклета. Он предназначен для печати на бумаге формата А4 в альбомной ориентации; Вот две страницы в PDF, которые должны соответствовать четырем страницам в настоящей книге.
-------------------------------
| | |
| | |
| | |
| (1) | (3) |
| | |
| | |
| | |
-------------------------------
-------------------------------
| | |
| | |
| | |
| (4) | (2) |
| | |
| | |
| | |
-------------------------------
Числа в скобках соответствуют порядку отдельных страниц.
Я знаю, что в linux есть все виды команд (pdfbook, pdfnup и т. Д.) (Которые, вероятно, использовались для создания этой брошюры). Как мне это «снять», то есть я хотел бы сделать из этого документ в формате pdf, где каждая отдельная страница конечного продукта представляет собой отдельную страницу pdf, упорядоченную обычным способом.
редактировать
Благодаря Жилю, мне удалось использовать следующий код:
import copy, sys
from pyPdf import PdfFileWriter, PdfFileReader
input = PdfFileReader(sys.stdin)
output = PdfFileWriter()
second_half = []
for i in range(0,input.getNumPages()):
p = input.getPage(i)
q = copy.copy(p)
print >> sys.stderr, 'splitting page',i
print >> sys.stderr, '\tlowerLeft:',p.mediaBox.lowerLeft
print >> sys.stderr, '\tupperRight:',p.mediaBox.upperRight
p.mediaBox.upperRight = (ur[0], (bl[1]+ur[1])/2)
p.mediaBox.lowerLeft = bl
q.mediaBox.upperRight = ur
q.mediaBox.lowerLeft = (bl[0], (bl[1]+ur[1])/2)
if i % 2 == 0:
output.addPage(p)
qold = q
else:
output.addPage(q)
output.addPage(qold)
output.addPage(p)
output.write(sys.stdout)