Python バッチで写真を PDF に変換します

Word 文書内の画像を PDF に変換および結合するコード。このコードは、まず指定されたパスから Word 文書内の画像を読み取り、次にその画像ファイルを指定されたフォルダー path_convert に保存します。次に、プログラムは画像が保存されているフォルダーをたどり、すべての画像ファイルを同じ名前の PDF ファイルに変換し、元の画像ファイルが存在するフォルダーに保存します。最後に、プログラムは同じフォルダー内のすべての PDF ファイルを、output.pdf という名前の 1 つのファイルに結合します。

PyPDF2 ライブラリは、PDF ファイルの結合に使用できる PdfMerger クラスを提供するため、コードにインストールする必要があることに注意してください。ライブラリがインストールされていない場合は、コマンド プロンプトまたはターミナルを開き、次のコマンドを使用してライブラリをインストールできます。

完全なコード:

# -*- coding: utf-8 -*-
"""
Spyder Editor

This is a temporary script file.
"""

from PIL import Image
import os
from os.path import join
from pathlib import Path
from PyPDF2 import PdfMerger


path = "C:/Users/ypzhao/Desktop/word/"
path_convert = "C:/Users/ypzhao/Desktop/pict/"

for i in os.listdir(path):
    file_name,file_suffix = i.split(".")
    if file_suffix != "jpg":
        im = Image.open(path+f"{
      
      i}")
        im.save(path_convert+f"{
      
      file_name}"+".jpg")       
    else:
        pass   

def convert_to_pdf(file_path):
    # 打开图片文件
    img = Image.open(file_path)
    # 将图片转换为 PDF,并保存到同名文件
    pdf_path = os.path.splitext(file_path)[0] + ".pdf"
    img.save(pdf_path, "PDF", resolution=300.0)

def main():
    # 指定图片所在目录
    image_dir = Path("C:/Users/ypzhao/Desktop/pict/")
    # 遍历目录下的所有文件
    for file_path in image_dir.glob("*"):
        # 如果是图片文件,则转换为 PDF
        if file_path.suffix.lower() in (".jpg", ".jpeg", ".png", ".bmp"):
            convert_to_pdf(file_path)
    # 将所有 PDF 合并成一个文件
    merger = PdfMerger()
    for file_path in image_dir.glob("*.pdf"):
        merger.append(str(file_path))
    merger.write("output.pdf")

if __name__ == "__main__":
    main()

操作結果:
ここに画像の説明を挿入

おすすめ

転載: blog.csdn.net/m0_58857684/article/details/130849482