Python一键删除PDF任意页:输入页码秒出干净文件------再也不用在线裁剪排队
PDF删页, 零依赖脚本, 命令行秒用, 小白神器, 瑞士军刀
故事开场:一把瑞士军刀救了你
周一早高峰,老板发来 200 页 PDF:
"把第 18、25、37 页删掉,10 分钟后开会!"
你打开浏览器找在线工具------排队 20 人,上传 80 MB,还提示"会员专享"。
这时,你从 U 盘掏出"小白瑞士军刀"------main.py
。
双击运行,按提示输入:
What is the file that you would like to modify?
>>> report.pdf
How many pages do you need to delete?
>>> 3
Enter the page numbers...
>>> 18 25 37
30 秒后,output.pdf
躺在桌面,只剩 197 页。
老板惊呼:"效率真高!"
痛点解决:再也不用在线排队、上传下载,本地 30 秒搞定。
完整代码(≤1000字符,直接展示)
python
from PyPDF2 import PdfFileWriter, PdfFileReader
print("请输入要处理的 PDF 路径:")
file = input()
pdf_in = PdfFileReader(file)
print("要删除几页?")
n = int(input())
pages_to_delete = []
print("请输入页码(每行一个):")
for _ in range(n):
pages_to_delete.append(int(input()) - 1) # 页码从 0 开始
pdf_out = PdfFileWriter()
for i in range(pdf_in.getNumPages()):
if i not in pages_to_delete:
pdf_out.addPage(pdf_in.getPage(i))
with open('output.pdf', 'wb') as f:
pdf_out.write(f)
print("完成!已生成 output.pdf")
代码解析
功能块 1:读取 PDF
PdfFileReader
把整本 PDF 加载到内存,后续操作零延迟。
python
pdf_in = PdfFileReader(file)
功能块 2:交互收集页码
用 input()
逐行收集用户想删的页码,减 1 转成 0 基索引,小白不会输错。
python
pages_to_delete.append(int(input()) - 1)
功能块 3:循环保留页面
遍历所有页码,不在删除列表就加入新 PDF,顺序不变。
python
for i in range(pdf_in.getNumPages()):
if i not in pages_to_delete:
pdf_out.addPage(pdf_in.getPage(i))
如果还想更厉害
扩展点子 1:命令行参数
加 -f report.pdf -p 18 25 37 -o cleaned.pdf
,一行搞定。
python
import argparse
parser = argparse.ArgumentParser()
parser.add_argument('-f', '--file', required=True)
parser.add_argument('-p', '--pages', nargs='+', type=int)
parser.add_argument('-o', '--output', default='output.pdf')
args = parser.parse_args()
扩展点子 2:图形界面
用 tkinter
拖文件选页码,按钮一键删除。
python
import tkinter.filedialog as fd
file = fd.askopenfilename(filetypes=[("PDF", "*.pdf")])
# 复用上面页码列表逻辑
总结
main.py
这把 20 行瑞士军刀,把"上传→排队→下载"三步压缩成"输入页码+回车"。
你无需安装任何大型软件,就能把 PDF 任意页秒删,顺序不乱。
再加两行参数或 GUI,它就从脚本升级成批量神器。
下次再遇"删两页"需求,直接跑脚本,30 秒收工!
源码获取
完整代码已开源,包含详细的注释文档:
🔗 [GitCode仓库] https://gitcode.com/laonong-1024/python-automation-scripts
📥 [备用下载] https://pan.quark.cn/s/654cf649e5a6 提取码:f5VG