我有一个图像文件列表,我想用这些图像生成一个output.pdf文件。
以下代码仅适用于一个图像文件(此处为image_list的第一个元素):
with open("output.pdf","wb") as f, io.BytesIO() as output:
img = Image.open(image_list[0])
img.save(output, format='tiff')
f.write(img2pdf.convert(output.getvalue()))
如何修改此代码以使用完整的图像文件列表?
我尝试过:
with open("output.pdf","wb") as f, io.BytesIO() as output:
img = Image.open(image_list[0])
img.save(output, format='tiff')
img2 = Image.open(image_list[1])
img2.save(output, format='tiff')
f.write(img2pdf.convert(output.getvalue()))
但是它不起作用(创建的pdf仅包含最后一张图像,即image_list [1])
答案 0 :(得分:1)
可能的黑客可能是通过ImageMagick's #include <stdbool.h>
运行它:
convert
答案 1 :(得分:0)
我终于使用了以下代码:
for i in....
# Create one pdf file per tiff file
with open(str(i) + '.pdf', "wb") as f, io.BytesIO() as output:
img = PIL.Image.open(str(i) + '.tiff')
img.save(output, format='tiff')
f.write(img2pdf.convert(output.getvalue()))
# merge the pdf file into one output pdf file
pdf_writer = PdfFileWriter()
output_file = publication_number + ".pdf"
file_list = os.listdir()
pdf_list = []
for file in file_list:
if file.endswith(".pdf"):
pdf_list.append(file)
pdf_list.sort(key=lambda f: int(
''.join(filter(str.isdigit, f)))) # trier la liste d'image du plus petit au plus grand (et pas 1, 10, 11, 2, 3)
for pdf_file in pdf_list:
pdf_reader = PdfFileReader(pdf_file)
for page in range(pdf_reader.getNumPages()):
pdf_writer.addPage(pdf_reader.getPage(page))
with open(output_file, 'wb') as fh:
pdf_writer.write(fh)
for i in range(1, max_page + 1):
os.remove(str(i) + '.tiff')
os.remove(str(i) + '.pdf')