【python实用小脚本-187】Python一键批量改PDF文字:拖进来秒出新文件——再也不用Acrobat来回导

Python一键批量改PDF文字:拖进来秒出新文件------再也不用Acrobat来回导

PDF文字替换, 批量导出, 零依赖转档, 一键完成, 瑞士军刀

故事开场:一把瑞士军刀救了周五下班的你

周五 18:00,老板甩来 50 份合同 PDF:

"把里面的'2023'全部改成'2024',今晚就要!"

你打开 Acrobat,发现要:

  1. 先导出 Word
  2. 逐个查找替换
  3. 再导回 PDF
    来回三遍,眼睛已花。
    这时,你从 U 盘掏出"小白瑞士军刀"------pdf_editor.py
    把 PDF 拖进去,一行命令:
bash 复制代码
python pdf_editor.py

30 秒后,50 份新 PDF 整整齐齐躺在文件夹,老板直呼"效率王"!

痛点解决:再也不用巨软全家桶,一键改字、一键导出。


完整代码(≤1000字符,直接展示)

python 复制代码
from docx import Document
from pdf2docx import parse
import subprocess, os

def pdf_to_word(pdf_file):
    parse(pdf_file, 'word.docx')

def edit_word(find, replacement):
    doc = Document('word.docx')
    for p in doc.paragraphs:
        if find in p.text:
            p.text = p.text.replace(find, replacement)
    doc.save('converted.docx')

def word_to_pdf():
    subprocess.run(["libreoffice", "--headless", "--convert-to", "pdf", 'converted.docx'])
    for tmp in ['word.docx', 'converted.docx']:
        if os.path.exists(tmp):
            os.remove(tmp)

if __name__ == "__main__":
    file, find, replace = input("格式:文件 旧文本 新文本> ").split()
    pdf_to_word(file)
    edit_word(find, replace)
    word_to_pdf()

代码解析

功能块 1:PDF → Word 零门槛

pdf2docx.parse 一行把 PDF 变成可编辑的 .docx,保留格式。

python 复制代码
parse(pdf_file, 'word.docx')

功能块 2:全文快速替换

遍历所有段落,直接 str.replace,比 Word 查找更快。

python 复制代码
for p in doc.paragraphs:
    if find in p.text:
        p.text = p.text.replace(find, replacement)

功能块 3:Word → PDF 一键回

用 LibreOffice 无头模式批量转 PDF,再清理中间文件。

python 复制代码
subprocess.run(["libreoffice", "--headless", "--convert-to", "pdf", 'converted.docx'])

如果还想更厉害

扩展点子 1:批量文件夹

把整目录 PDF 一次性改字,自动按原名输出。

python 复制代码
import glob
for pdf in glob.glob('*.pdf'):
    pdf_to_word(pdf)
    edit_word('2023', '2024')
    word_to_pdf()
    os.rename('converted.pdf', pdf.replace('.pdf', '_new.pdf'))

扩展点子 2:GUI拖放窗口

tkinter 做窗口,拖文件+输入框即完成。

python 复制代码
import tkinter.filedialog as fd
pdf_path = fd.askopenfilename()
# 复用上面三步

总结

pdf_editor.py 这把 40 行瑞士军刀,把"PDF→Word→替换→PDF"四步压缩成"拖进去+回车"。

你无需安装 Acrobat,就能在 Linux/Mac/Windows 上批量改字、批量导出。

再加两行循环或 GUI,它就从脚本升级成 PDF 工厂。

下次再遇"批量改合同",直接跑脚本,省时省力!

源码获取

完整代码已开源,包含详细的注释文档:

🔗 [GitCode仓库] https://gitcode.com/laonong-1024/python-automation-scripts

📥 [备用下载] https://pan.quark.cn/s/654cf649e5a6 提取码:f5VG

相关推荐
dbdr0901几秒前
Linux 入门到精通,真的不用背命令!零基础小白靠「场景化学习法」,3 个月拿下运维 offer,第二十六天
linux·运维·服务器·网络·python·学习
花花无缺5 分钟前
python自动化-pytest-用例发现规则和要求
后端·python
冷冷的菜哥20 分钟前
ASP.NET Core文件分片上传
c#·asp.net·asp.net core·文件分片上传
YUELEI11836 分钟前
langchain 提示模版 PromptTemplate
python·langchain
东方不败之鸭梨的测试笔记39 分钟前
LangChain: Models, Prompts 模型和提示词
人工智能·python·langchain
AI Echoes1 小时前
别再手工缝合API了!开源LLMOps神器LMForge,让你像搭积木一样玩转AI智能体!
人工智能·python·langchain·开源·agent
AI Echoes1 小时前
从零构建企业级LLMOps平台:LMForge——支持多模型、可视化编排、知识库与安全审核的全栈解决方案
人工智能·python·langchain·开源·agent
beijingliushao2 小时前
58-正则表达式
数据库·python·mysql·正则表达式
陈敬雷-充电了么-CEO兼CTO2 小时前
具身智能多模态感知与场景理解:融合语言模型的多模态大模型
人工智能·python·gpt·语言模型·自然语言处理·chatgpt·多模态
荔枝吻2 小时前
【AI总结】Python BERT 向量化入门指南
人工智能·python·bert