【PDF PicKiller】PDF批量删除固定位置图片工具,默认解密,可去一般图、背景图、水印图!

PDF批量删除固定位置图片工具 PDF PicKiller

  • [<center>PDF PicKiller [Download](https://github.com/Peaceful-World-X/PDF-PicKiller)](#
    PDF PicKiller Download)
  • [🤩 工具介绍](#🤩 工具介绍)
  • [🥳 主要功能](#🥳 主要功能)
  • [🤪 软件使用](#🤪 软件使用)
  • [🤪 参数解释](#🤪 参数解释)
  • [🤪 关键代码](#🤪 关键代码)
  • [🤩 项目代码](#🤩 项目代码)

PDF PicKiller Download

🤩 工具介绍

PDF PicKiller 是基于Python的PDF批处理工具,默认无感解密,使用命令行界面批量删除固定位置图像、渐变背景图、水印图或字,后续还有可能添加新功能,额...如果软件有用的话~

🥳 主要功能

✨ 默认解密:无感处理(破解)加密的 PDF 文件(有打开权限),支持多种加密方式:RC4 128bits, AES 128bits, AES 256bits 等。

✨对象提取:检索模板页(默认第1页),并列出 XObject 图像、Shadings 背景图像和 Form 水印图。

✨批量删除:批量高效的删除列出的图像对象,平均速度为 0.2 秒 处理每 1000 页(每页 5 个删除对象)。

✨交互式命令行:命令行界面,表情样式可爱回复~

🤪 软件使用

  1. 命令行绿色可执行文件,双击食用~
  2. 直接拖入PDF文件,或输入文件地址
  3. 选择模板页(即有要删除图片的页面),默认第一页则回车
  4. 选择模板页中要删除的对象名,默认删除全部对象则回车
  5. 已批量删除打开文件路径~
  6. 随时按下 Ctrl+C 退出软件!

🤪 参数解释

文档一般图片:

  • 名字: /IM13, 宽度: 674, 高度: 149
  • 名字: /IM15, 宽度: 640, 高度: 640
    【这是一般图片,通过宽度和高度来区别,IM15高度更大,IM13高度更小】

渐变背景图片:

  • 名字: /FXS1, 类型: 2-径向渐变 (Radial), 坐标: [554.0, 0.85, 554.0, 253.6]
  • 名字: /FXS2, 类型: 2-径向渐变 (Radial), 坐标: [5.0321, 9.2981, 548.518, 249.612]
    【这是背景图片,通过渐变线起始坐标来区别,FXS1是水平渐变,FXS2是对角渐变】

水印图片:

  • 名字: /Form4, 类型: 图片, 边界: [0.0, 0.0, 182.0, 45.0]
  • 名字: /KSPX191, 类型: 文字, 边界: [0.0, -7.272, 288.0, 67.464]
    【这是水印图字,通过类型和边界框起始坐标来区别,Form4高度更小,KSPX191高度更大】

🤪 关键代码

  1. PDF解密
python 复制代码
import pikepdf
pdf = pikepdf.open(input_pdf_path)

# 判断是否加密
if not pdf.is_encrypted:
	pdf.close()
	return input_pdf_path
pdf.close()
# 如果加密,重新用密码打开
pdf = pikepdf.open(input_pdf_path)
output_file = input_pdf_path.replace('.pdf', '(decrypted).pdf')
pdf.save(output_file)
pdf.close()
print(f"\033[31m✅ 解密成功,保存为 {output_file}\033[0m")
return output_file
  1. 识别对象
python 复制代码
def list_xobjects_and_shadings(page):
    result = {
        'images': [],  # 每个元素是 (name, width, height)
        'shadings': [],  # 每个元素是 (name, shading_type, coords)
        'watermarks': []  # 每个元素是 (name, resources, bbox)
    }
    try:
        resources = page.obj.get('/Resources')
        shadings = resources.get('/Shading')
        xobjects = resources.get('/XObject')
        # 处理XObject图像
        if xobjects is None: return result
        for name, obj_ref in xobjects.items():
            try:
                obj = obj_ref.get_object()
                subtype = obj.get('/Subtype')
                if subtype == '/Image':
                    width = obj.get('/Width', 'Unknown')
                    height = obj.get('/Height', 'Unknown')
                    result['images'].append((name, width, height))
                elif subtype == '/Form':  # 检查是否为水印 (Form)
                    # 提取水印的资源和边界框
                    resources = obj.get('/Resources', 'Unknown')
                    bbox = obj.get('/BBox', 'Unknown')
                    bbox_list = [float(coord) for coord in bbox] if bbox else None
                    result['watermarks'].append((name, resources, bbox_list))
            except Exception as e_inner:
                print(f"⚠️ 哎呀! 无法读取 {name} 对象: {type(e_inner).__name__}: {e_inner}")
                continue
        # 处理Shading图像
        if shadings is None: return result
        for name, obj_ref in shadings.items():
            try:
                obj = obj_ref.get_object()
                obj = obj_ref
                shading_type = obj.get('/ShadingType', 'Unknown')
                coords = obj.get('/Coords', None)
                coords_list = [float(coord) for coord in coords] if coords else None
                result['shadings'].append((name, shading_type, coords_list))
            except Exception as e_inner:
                print(f"⚠️ 哎呀! 无法读取 Shading {name}: {type(e_inner).__name__}: {e_inner}")
                continue
    except Exception as e:
        print(f"⚠️ 糟糕! 列出XObject时出错: {type(e).__name__}: {e}")
    return result

🤩 项目代码

https://github.com/Peaceful-World-X/PDF-PicKiller

✨欢迎反馈BUG,后续会视情况添加新功能!
(代码是晚上为了处理一个PDF文件临时写的,有问题非常欢迎反馈~)

相关推荐
一只花里胡哨的程序猿10 小时前
odoo打印pdf速度慢问题
pdf·odoo
灵海之森12 小时前
Python将md转html,转pdf
pdf
阿幸软件杂货间16 小时前
最新PDF版本!Acrobat Pro DC 2025,解压即用版
pdf·adobe acrobat·acrobat
星空的资源小屋18 小时前
网易UU远程,免费电脑远程控制软件
人工智能·python·pdf·电脑
会飞的小菠菜21 小时前
如何一次性将多个PPT幻灯片批量转换成PDF文档
pdf·powerpoint·ppt·批量·格式转换
somethingGoWay1 天前
wpf .netcore 导出pdf文件
pdf·wpf·.netcore
小白电脑技术1 天前
PDF教程|如何把想要的网页保存下来?
pdf·电脑
我没想到原来他们都是一堆坏人1 天前
通过Gen AI SDK调用gemini 2.5 pro,单独上传pdf文件 | ai agent 开发笔记 2025.9.2 Day 2
ai·google·pdf·sdk·gemini
AI视觉网奇2 天前
麒麟系统 doc转pdf
linux·运维·pdf
CodeCraft Studio2 天前
国产化PDF处理控件Spire.PDF教程:如何在 Java 中通过模板生成 PDF
java·python·pdf·spire.pdf·java创建pdf·从html创建pdf