python-pdf的去水印操作
python-特殊pdf的去水印操作
- 为什么做出这个?
- 原理
- 特色
- 成果
- 安装依赖
- 代码
- 想法
- 参考文献
为什么做出这个?
- 就是有时候从网上下载的资料中的pdf有水印,看着不舒服。
- 比如说我从网上下载的试卷,然后去打印店打印,打印之后水印看着很不舒服,而去水印wps要会员,而我是一个程序员,为什么不做一个呢,何乐而不为。
- 虽然最后是
做出来的,但是还是有限制
。
原理
- 把pdf
转化为图片
,然后将图片去水印
。 - 图片去水印,是又
条件限制
的,必须水印的颜色和pdf中文字的颜色的rgb相差很大
,然后把水印的颜色改变成背景颜色。
特色
- 网上很多和我类似的原理去水印,但是都是先pdf转化为图片存起来,然后图片去水印之后,然后把图片拼接成pdf。
- 而我就
不需要中间步骤
,我是直接输入pdf文件,输出pdf文件
。
成果
安装依赖
- Image
pip install pillow
- fitz
pip install PyMuPDF
代码
- 程序处理pdf需要的时间
比较久
(因为处理的是像素点),可以先用页数少的pdf进行测试之后再去页数比较多的pdf。
from PIL import Image
import os
import io
import fitz
import timedef single_pdf_clearwater(pdf_path: str):pdf = fitz.open(pdf_path) # 打开pdf目录pdf_img = fitz.open() # 打开空文件,用来存图片pdffor page_inf in pdf:definition = 3 # 清晰度,感觉输出的pdf不够清晰,可以调大,调大,文件大小也会变大matrix = fitz.Matrix(definition, definition)img = page_inf.get_pixmap(matrix=matrix).tobytes()img = Image.open(io.BytesIO(img))width, height = img.sizefor i in range(width):for j in range(height):if sum(img.getpixel((i, j))) > 600: # 这里的600你需要根据自己的水印的颜色进行更改。img.putpixel((i, j), (255, 255, 255))img = img.tobytes() # = img = np.asarray(img);img = bytearray(img)img = fitz.Pixmap(fitz.csRGB, width, height, img)img = img.tobytes()img = fitz.open("png", img)pdf_bytes = img.convert_to_pdf()pdf_img.insert_pdf(fitz.open("pdf", pdf_bytes))if not os.path.exists("output"):os.makedirs("output") # 处理好的pdf存入了output目录下pdf_img.save("output/去水印pdf_" + os.path.basename(pdf_path))def group_pdf_clearwater(path_array: list[str]):print("************去水印时间比较久***********")for pdf_path in path_array:print(pdf_path, "去水印中...")single_pdf_clearwater(pdf_path)print("完成")def folder_pdf_files(folder: str) -> list[str]: # 一个文件夹里面有多少pdf文件file_list = []for a, b, c in os.walk(folder):for filename in c:if filename[-3:].lower() == 'pdf':file_path = os.path.join(a, filename)file_list.append(file_path)print(folder, ": 有", len(file_list), "个pdf文件")return file_listif __name__ == '__main__':time_start = time.time()path_list = folder_pdf_files("pdf的目录")group_pdf_clearwater(path_list)time_end = time.time()print("程序运行时间:", round(time_end - time_start, 2), "秒")
想法
- 虽然最后实现了,但是
有限制
。 - 为了去除保存图片后取图片的中间步骤,我查阅了很多的文献和资料,后面发现只有我最不想看的
英文文档才找到了问题的答案
。我就感觉,比较偏的点,只有英文文献才有。 - 因为限制,我在想是不是可以和python-普通pdf的添加水印的
逆向思维
进行操作,就是把水印图层直接取出来。 - 如果处理的pdf文件比较多,并且页数很多,程序运行就要很久,我都感觉像深度学习了
python-pdf的去水印操作相关推荐
- python怎么玩pdf_如何使用Python玩转PDF各种骚操作?
Portable Document Format(可移植文档格式),或者PDF是一种文件格式,可以用于跨操作系统的呈现和文档交换.尽管PDF最初是由Adobe发明的,但它现在是由国际标准化组织(ISO ...
- 如何使用Python玩转PDF各种骚操作?
点击"小詹学Python",选择"置顶"公众号 重磅干货,第一时间送达 本文转载自Python数据科学,禁二次转载 Portable Document Form ...
- Python自动化办公:pdf文档操作
在后台回复[阅读书籍] 即可获取python相关电子书~ Hi,我是山月. 之前给大家介绍了python处理excel.word.ppt的相关教程,不知道大家学的怎么样? 在后台回复[自动化办公]即可 ...
- PDF怎么去水印,PDF去水印工具怎么操作
PDF怎么去水印呢?很多人为了防止自己的PDF文件被冒用,就会选择在自己的PDF文件上面加上水印,如果想要下载别人的PDF文件并使用的话就需要将PDF文件上面的水印删除,小编推荐使用迅捷PDF编辑器来 ...
- PDF如何去水印?PDF去水印的基础操作
PDF如何去除水印?从网上下载的PDF文件很多都是有水印的,自己修改PDF文件后有别人的水印始终是不好的,所以我们在使用的时候就需要将PDF文件中的水印去除掉,那么PDF去除水印怎么操作呢?今天就来为 ...
- Python爬虫:多线程的应用和pdf文件相关操作
多线程的应用 前程无忧岗位爬虫 import requests from re import search from multiprocessing import Process, Queue fro ...
- python 怎么将数组转为列表_图片转换成pdf格式怎么操作?什么软件能将图片转为pdf?...
伙伴们好,你们知道如何把图片转为pdf格式吗?前一阵子我参加了一个家居行业大会,在会议上拍摄了不少会议照片,包括主持人讲话.嘉宾出席.观众提问.产品推广等环节都拍摄了不同的角度.拍摄好后,需要传送给写 ...
- python pdf报告_Python实现html转换为pdf报告(生成pdf报告)功能示例
本文实例讲述了Python实现html转换为pdf报告(生成pdf报告)功能.分享给大家供大家参考,具体如下: 1.先说下html转换为pdf:其实支持直接生成,有三个函数pdfkit.f 安装pyt ...
- Python文件的读写操作
使用Python编程时,经常会遇到读写文件的操作.对于读写文件的各种模式(如阅读.写入.追加等)有时真的会迷惑人,以及搞不清open.read.readline.readlines.write.wri ...
最新文章
- 通过修改注册表提升SSD性能(Intel 5系列芯片组)
- 三星6.0系统手机最简单激活XPOSED框架的教程
- 用SQL语句添加删除修改字段
- jdbc-------JDBCUtil类 工具类
- Redis 与 key 相关的常用命令
- hadoop的Avro数据序列化系统
- [转载] 树莓派并行控制电机_使用由并行端口控制的软盘驱动步进电机的相机摇摄器
- android中自适应布局教程,Android实现自适应正方形GridView
- sublime text3 快捷方式汇总
- 使用Ajax时常用的转码方法encodeURI,escape,encodeURI
- efficientnet
- 69期-Java SE-036_MySQL-7 SQL练习 -doing
- vue如何通过NodeJs本地获取微信access_token及签名,并调用微信接口
- 前馈神经网络(FNN)
- 菜鸡的秋招升级打怪之旅
- 科目三必看要点 驾驶经验汇总
- 基于RNN,LSTM,GRU对黄金期货的时间序列研究
- what‘s a work you can not do
- 2022-2028全球植物奶油行业调研及趋势分析报告
- 全球存储市场的当下格局与未来发展
热门文章
- python怎么玩pdf_如何使用Python玩转PDF各种骚操作?