当前位置: 首页 > news >正文

【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 拖进去,一行命令:
python pdf_editor.py

30 秒后,50 份新 PDF 整整齐齐躺在文件夹,老板直呼“效率王”!
痛点解决:再也不用巨软全家桶,一键改字、一键导出。


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

from docx import Document
from pdf2docx import parse
import subprocess, osdef 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,保留格式。

parse(pdf_file, 'word.docx')

功能块 2:全文快速替换

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

for p in doc.paragraphs:if find in p.text:p.text = p.text.replace(find, replacement)

功能块 3:Word → PDF 一键回

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

subprocess.run(["libreoffice", "--headless", "--convert-to", "pdf", 'converted.docx'])

如果还想更厉害

扩展点子 1:批量文件夹

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

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 做窗口,拖文件+输入框即完成。

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

http://www.dtcms.com/a/333493.html

相关文章:

  • 详解 k 近邻(KNN)算法:原理、实践与调优 —— 以鸢尾花分类为例
  • JUC LongAdder并发计数器设计
  • 指针操作:从到*的深度指南
  • JavaWeb开发_Day13
  • Cortex-Debug和openocd之间的关系?如何协同工作?
  • 《人形机器人的觉醒:技术革命与碳基未来》——触觉反馈系统:电子皮肤的概念、种类、原理及在机器中的应用
  • 攻防世界—fakebook(两种方法)
  • docker重启或系统重启后harbor自动启动
  • 深入理解C++正则表达式:从基础到实践
  • ReasonRank:从关键词匹配到逻辑推理,排序准确性大幅超越传统方法
  • Apifox接口测试工具
  • Unity输入系统:旧版Input_System
  • 第四章:大模型(LLM)】06.langchain原理-(3)langchain 数据连接方法
  • kubernetes(4) 微服务
  • 前往中世纪 送修改器(Going Medieval)免安装中文版
  • AI大模型配置项
  • 【mysql数据库全部重点知识】
  • 企业级时序数据库选型指南:从传统架构向智能时序数据管理的转型之路
  • 昆仑万维重磅发布Mureka V7.5与MoE-TTS,AI音乐与语音合成再升级!
  • 嵌入式学习 day52 IMX6ULL裸机开发-I2C
  • 基于Spring Boot的智能民宿预订与游玩系统设计与实现 民宿管理系统 民宿预订系统 民宿订房系统
  • 蓝桥杯 二叉树
  • [ CSS 前端 ] 网页内容的修饰
  • linux下找到指定目录下最新日期log文件
  • liteflow
  • CSS从入门到精通完整指南
  • 【学习笔记】Java并发编程的艺术——第8章 Java中的并发工具类
  • Python工具箱系列(六十二)
  • 写作在学习中的重要性
  • 【完整源码+数据集+部署教程】脑部健康状态检测系统源码和数据集:改进yolo11-AIFI