使用Python轻松拆分PDF,每页独立成文件

使用Python轻松拆分PDF,每页独立成文件 🎉

嗨,各位PDF爱好者!📚 如果你曾经有想要拆分一个大PDF文件的想法,让每一页都成为独立的文件,那么这篇博客就是为你准备的!我们将使用Python中的一个非常强大的库--PyPDF2,把这些需求变得简单易行。

PyPDF2登场 🎭

首先,我们需要安装PyPDF2库。如果你还没有安装,别担心,只需要在终端运行以下命令:

bash 复制代码
pip install PyPDF2

安装好了吗?下面我们就来coding了!

代码实现

这里有一段简单的Python代码,它能帮你分割PDF文件并保存成多个单页PDF。代码很简洁明了,让我们一块看看:

python 复制代码
import os
from PyPDF2 import PdfReader, PdfWriter


def split_pdf(input_pdf, output_folder):
    """
    将输入的 PDF 文件拆分成单页 PDF 文件

    参数:
        input_pdf: 输入的 PDF 文件路径
        output_folder: 输出目录
    """
    # 确保输出文件夹存在
    if not os.path.exists(output_folder):
        os.makedirs(output_folder)

    # 获取文件名(不含扩展名)
    file_name = os.path.splitext(os.path.basename(input_pdf))[0]

    # 读取 PDF 文件
    reader = PdfReader(input_pdf)
    total_pages = len(reader.pages)

    print(f"开始拆分 PDF 文件 '{input_pdf}',共 {total_pages} 页...")

    # 逐页拆分
    for page_num in range(total_pages):
        writer = PdfWriter()
        writer.add_page(reader.pages[page_num])

        output_filename = f"{file_name}_page_{page_num + 1:03d}.pdf"
        output_path = os.path.join(output_folder, output_filename)

        with open(output_path, "wb") as output_file:
            writer.write(output_file)

        print(f"已保存第 {page_num + 1} 页到 '{output_filename}'")

    print(f"PDF 拆分完成!所有页面已保存到目录 '{output_folder}'")


def main(input_pdf):
    output_folder = "output"  # 设定输出目录为output
    split_pdf(input_pdf, output_folder)


if __name__ == '__main__':
    main("te.pdf")  # 使用你要拆分的PDF文件路径

解读代码 🤔

  1. 导入必要模块

    • os: 用于操作路径。
    • PyPDF2: 核心库,用于PDF的读写。
  2. split_pdf 函数

    • 参数input_pdf是你想要拆分的PDF的路径,output_folder是你希望保存分割后文件的目录。
    • 确保输出目录存在,如果不存在则创建它。
    • 使用PdfReader读取PDF文件。
    • 获取文件的页数并开始逐页写入新的单页PDF。
  3. 主程序

    • 设置输出目录。
    • 调用split_pdf函数对指定的PDF文件进行拆分。

使用方法

将代码保存为一个.py文件,并在合适的环境(如命令行或IDE)中运行。记得将main函数中的"te.pdf"替换为你实际要处理的PDF文件路径哦!✍️

这就是全部了!这样一个简单的脚本,现在你就可以开始拆分你的PDF文件啦!如果你觉得有用或者有任何疑问,欢迎留言讨论!希望这篇文章能让你的生活更高效!🌟📄

Happy Coding! 🤓

相关推荐
Y1nhl1 小时前
搜广推校招面经五十五
人工智能·python·深度学习·机器学习·广告算法·推荐算法·搜索算法
老大白菜2 小时前
lunar是一款无第三方依赖的公历 python调用
前端·python
半梅芒果干3 小时前
pdf文件分页按需查看
pdf·vue
背着代码的蜗牛8 小时前
Pycharm远程开发注意事项
ide·python·pycharm·ssh·远程工作
墨绿色的摆渡人8 小时前
pytorch小记(十二):pytorch中 masked_fill_() vs. masked_fill() 详解
人工智能·pytorch·python
csdnsqst00508 小时前
QAI AppBuilder 快速上手(7):目标检测应用实例
python·ai·qualcomm·appbuilder·qnn·wos
mosquito_lover18 小时前
Python基于深度学习的多模态人脸情绪识别研究与实现
python·音视频·语音识别
@jerry_tu9 小时前
DeepSeek Chat 自动化交互技术分析
运维·python·自动化
赛卡9 小时前
Python直方图:从核密度估计到高维空间解析
开发语言·人工智能·python·matlab