用DeepSeek生成批量删除处理 PDF第一页工具

安装依赖库

在运行程序之前,请确保安装所需的库:

python 复制代码
pip install pymupdf python-docx

Python 程序代码

python 复制代码
import os
import fitz  # PyMuPDF
from docx import Document

def delete_pdf_first_page(input_path, output_path):
    """
    删除 PDF 文件的第一页并保存
    :param input_path: 输入的 PDF 文件路径
    :param output_path: 输出的 PDF 文件路径
    """
    # 打开 PDF 文件
    pdf_document = fitz.open(input_path)
    
    # 删除第一页
    pdf_document.delete_page(0)
    
    # 保存修改后的 PDF
    pdf_document.save(output_path)
    pdf_document.close()
    print(f"已处理并保存: {output_path}")

def delete_word_first_page(input_path, output_path):
    """
    删除 Word 文件的第一页内容并保存
    :param input_path: 输入的 Word 文件路径
    :param output_path: 输出的 Word 文件路径
    """
    # 打开 Word 文件
    doc = Document(input_path)
    
    # 获取第一页的内容范围
    # 假设第一页的内容在前 500 个字符内(可以根据实际情况调整)
    first_page_content = doc.paragraphs[:10]  # 取前 10 段作为第一页内容
    
    # 删除第一页的内容
    for paragraph in first_page_content:
        p = paragraph._element
        p.getparent().remove(p)
    
    # 保存修改后的 Word 文件
    doc.save(output_path)
    print(f"已处理并保存: {output_path}")

def batch_process_files(folder_path, output_folder):
    """
    批量处理文件夹中的 PDF 和 Word 文件
    :param folder_path: 输入文件夹路径
    :param output_folder: 输出文件夹路径
    """
    # 确保输出文件夹存在
    if not os.path.exists(output_folder):
        os.makedirs(output_folder)
    
    # 遍历文件夹中的文件
    for filename in os.listdir(folder_path):
        file_path = os.path.join(folder_path, filename)
        output_path = os.path.join(output_folder, filename)
        
        try:
            # 处理 PDF 文件
            if filename.lower().endswith('.pdf'):
                print(f"正在处理 PDF 文件: {filename}")
                delete_pdf_first_page(file_path, output_path)
            
            # 处理 Word 文件
            elif filename.lower().endswith('.docx'):
                print(f"正在处理 Word 文件: {filename}")
                delete_word_first_page(file_path, output_path)
            
            else:
                print(f"跳过不支持的文件: {filename}")
        except Exception as e:
            print(f"处理文件 {filename} 时出错: {e}")

if __name__ == "__main__":
    # 输入文件夹路径(包含 PDF 和 Word 文件)
    input_folder = "F:\\python\\pdf"  # 替换为你的输入文件夹路径
    
    # 输出文件夹路径
    output_folder = "F:\\python\\firstpage"  # 替换为你的输出文件夹路径
    
    # 批量处理文件
    batch_process_files(input_folder, output_folder)

程序说明

  1. PDF 文件处理

    • 使用 PyMuPDF 打开 PDF 文件,删除第一页并保存。

    • 注意:PyMuPDFdelete_page 方法直接删除指定页面。

  2. Word 文件处理

    • 使用 python-docx 打开 Word 文件,删除第一段内容(模拟删除第一页)。

    • 注意:python-docx 不支持直接删除页面,因此通过删除第一段内容来实现。

  3. 批量处理

    • 程序会遍历指定文件夹中的所有文件,自动识别 PDF 和 Word 文件并处理。

清华大学DeepSeek整套学习资料(持续更新)链接:https://pan.quark.cn/s/24136c2b13e8

相关推荐
SunnyDays10115 分钟前
如何使用 C# 创建、修改和删除 Excel 中的 VBA 宏(无需Microsoft Excel)
c#·excel·vba宏·创建vba宏·修改vba宏·删除vba宏
jwn99911 分钟前
Laravel11.x新特性全解析
android·开发语言·php·laravel
feifeigo12313 分钟前
航天器交会的分布式模型预测控制(DMPC)MATLAB实现
开发语言·分布式·matlab
于先生吖13 分钟前
支持二开与商用,JAVA 漫剧付费观看系统完整源码
java·开发语言
环黄金线HHJX.14 分钟前
【从0到1】
开发语言·人工智能·算法·交互
曹牧15 分钟前
Java: 从oracle表中获取一组kv序列
java·开发语言·oracle
深邃-16 分钟前
【C语言】-数据在内存中的存储(1)
c语言·开发语言·数据结构·c++·算法
Lyyaoo.17 分钟前
【Java基础面经】Java 注解的底层原理
java·开发语言·python
妙蛙种子31118 分钟前
【Java设计模式 | 创建者模式】 抽象工厂模式
java·开发语言·后端·设计模式·抽象工厂模式
zhaoshuzhaoshu19 分钟前
Bash 与 Dash 的区别与联系
开发语言·bash·dash