J'ai un fichier pdf qui a été créé dans un format de brochure. Il est destiné à imprimer sur du papier A4 en orientation paysage; voici deux pages dans le pdf, qui devraient correspondre à quatre pages dans le livre actuel.
-------------------------------
| | |
| | |
| | |
| (1) | (3) |
| | |
| | |
| | |
-------------------------------
-------------------------------
| | |
| | |
| | |
| (4) | (2) |
| | |
| | |
| | |
-------------------------------
Les numéros entre parenthèses correspondent à l'ordre des pages individuelles.
Je sais qu'il y a toutes sortes de commandes (pdfbook, pdfnup, etc.) sur linux (qui a probablement été utilisé pour faire ce livret en premier lieu). Comment le «décompresser» - c'est-à-dire que j'aimerais faire un document pdf à partir de là où chaque page individuelle du produit final est une page individuelle du pdf, commandée de la manière habituelle.
Éditer
Grâce à Gilles, j'ai réussi à utiliser le code suivant:
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)