Python实现为PDF去除水印的示例代码


Posted in Python onApril 03, 2022

前言

为什么做出这个?

就是有时候从网上下载的资料中的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 time


def single_pdf_clearwater(pdf_path: str):
    pdf = fitz.open(pdf_path)   # 打开pdf目录
    pdf_img = fitz.open()       # 打开空文件,用来存图片pdf
    for 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.size
        for 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):
        if b == []:
            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_list


if __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 相关文章推荐
使用Python制作获取网站目录的图形化程序
May 04 Python
python中sys.argv函数精简概括
Jul 08 Python
Python中is和==的区别详解
Nov 15 Python
对python中dict和json的区别详解
Dec 18 Python
提升Python程序性能的7个习惯
Apr 14 Python
Python+AutoIt实现界面工具开发过程详解
Aug 07 Python
django中间键重定向实例方法
Nov 10 Python
Keras设定GPU使用内存大小方式(Tensorflow backend)
May 22 Python
Python利用Xpath选择器爬取京东网商品信息
Jun 01 Python
Keras 利用sklearn的ROC-AUC建立评价函数详解
Jun 15 Python
Python colormap库的安装和使用详情
Oct 06 Python
高考要来啦!用Python爬取历年高考数据并分析
Jun 03 Python
Python实现文字pdf转换图片pdf效果
Apr 03 #Python
python 实现图片特效处理
教你使用Python获取QQ音乐某个歌手的歌单
Python os和os.path模块详情
如何通过一篇文章了解Python中的生成器
Python pyecharts绘制条形图详解
Python OpenCV超详细讲解读取图像视频和网络摄像头
You might like
JAVA/JSP学习系列之二
2006/10/09 PHP
php 字符串替换的方法
2012/01/10 PHP
ThinkPHP模版中导入CSS和JS文件的方法
2014/11/29 PHP
php注册登录系统简化版
2020/12/28 PHP
php通过curl添加cookie伪造登陆抓取数据的方法
2016/04/02 PHP
Zend Framework入门教程之Zend_Registry组件用法详解
2016/12/09 PHP
jQuery 工具函数学习资料
2010/04/29 Javascript
阻止子元素继承父元素事件具体思路及实现
2013/05/02 Javascript
下拉列表select 由左边框移动到右边示例
2013/12/04 Javascript
javascript实现图片循环渐显播放的方法
2015/02/24 Javascript
jQuery实现信息提示框(带有圆角框与动画)效果
2015/08/07 Javascript
JavaScript判断表单中多选框checkbox选中个数的方法
2015/08/17 Javascript
jQuery基础_入门必看知识点
2016/07/04 Javascript
轻松实现js弹框显示选项
2016/09/13 Javascript
canvas 画布在主流浏览器中的尺寸限制详细介绍
2016/12/15 Javascript
Bootstrap免费字体和图标网站(值得收藏)
2017/03/16 Javascript
基于BootStrap的前端分页带省略号和上下页效果
2017/05/18 Javascript
nodejs模块学习之connect解析
2017/07/05 NodeJs
Vue+webpack实现懒加载过程解析
2020/02/17 Javascript
JS实现随机点名器
2020/04/12 Javascript
js实现限定区域范围拖拉拽效果
2020/11/20 Javascript
Python实现随机选择元素功能
2017/09/14 Python
Python使用sax模块解析XML文件示例
2019/04/04 Python
Python实现字符串匹配的KMP算法
2019/04/04 Python
Python Tkinter 简单登录界面的实现
2019/06/14 Python
Django实现web端tailf日志文件功能及实例详解
2019/07/28 Python
如何用Python提取10000份log中的产品信息
2021/01/14 Python
纯CSS3代码实现switch滑动开关按钮效果
2016/08/30 HTML / CSS
LORAC官网:美国彩妆品牌
2019/08/27 全球购物
巴西购物网站:Onofre Agora
2020/06/08 全球购物
营业员实习自我鉴定
2013/12/07 职场文书
企业演讲比赛主持词
2014/03/18 职场文书
鸿星尔克广告词
2014/03/21 职场文书
写给女朋友的保证书
2015/05/09 职场文书
发言稿之优秀教师篇
2019/09/26 职场文书
只用50行Python代码爬取网络美女高清图片
2021/06/02 Python