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

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

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

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

Alt

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解密
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. 识别对象
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 resultfor 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 Noneresult['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 resultfor name, obj_ref in shadings.items():try:obj = obj_ref.get_object()obj = obj_refshading_type = obj.get('/ShadingType', 'Unknown')coords = obj.get('/Coords', None)coords_list = [float(coord) for coord in coords] if coords else Noneresult['shadings'].append((name, shading_type, coords_list))except Exception as e_inner:print(f"⚠️ 哎呀! 无法读取 Shading {name}: {type(e_inner).__name__}: {e_inner}")continueexcept Exception as e:print(f"⚠️ 糟糕! 列出XObject时出错: {type(e).__name__}: {e}")return result

🤩 项目代码

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

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

相关文章:

  • 排序算法总结(C++)
  • win中将pdf转为图片
  • Python读取PDF:文本、图片与文档属性
  • git提交代码和解决冲突修复bug
  • PDF 转 Markdown
  • java 实现excel文件转pdf | 无水印 | 无限制
  • LangChain【6】之输出解析器:结构化LLM响应的关键工具
  • 佰力博科技与您探讨材料介电性能测试的影响因素
  • Mysql中select查询语句的执行过程
  • 埃文科技智能数据引擎产品入选《中国网络安全细分领域产品名录》
  • MySQL基础(三)DQL(Data Query Language,数据查询语言)
  • vue+elementui 网站首页顶部菜单上下布局
  • 七、数据库的完整性
  • keysight是德科技N9923A网络分析仪
  • 【NLP中向量化方式】序号化,亚编码,词袋法等
  • vb监测Excel两个单元格变化,达到阈值响铃
  • Excel 发现此工作表中有一处或多处公式引用错误。请检查公式中的单元格引用、区域名称、已定义名称以及到其他工作簿的链接是否均正确无误。弹窗
  • ArcGIS安装时输入localhost不被识别
  • Vue在线预览excel、word、ppt等格式数据。
  • 96. 2017年蓝桥杯省赛 - Excel地址(困难)- 进制转换
  • 网站建设销售一个月开几个单/seo有哪些优化工具
  • 建筑网站汇总/搜狗推广登录
  • 有什么正网站做兼职的/windows优化大师要会员
  • 凯里建设局网站/长沙百家号seo
  • 劳动仲裁院内部网站建设/推广普通话
  • 网站售后服务模板/百度账号怎么改名字