Python3,2段代码,给pdf文件添加水印,原来watermark还可以这么玩。

简介: Python3,2段代码,给pdf文件添加水印,原来watermark还可以这么玩。

1、 引言


小屌丝:鱼哥,新年快乐!

小鱼:无事不登三宝殿,有啥事,你直说吧…

小屌丝:别说的这么直接,这大过年的…

小鱼:别整没用的,就你那点小心思,我还能不知道。

小屌丝:…


小屌丝:鄙视就鄙视,只要能帮我解决问题,我然你鄙视三连!

小鱼:…还可以这样,那你说吧,啥事?

小屌丝:就是…就是…

小鱼:能不能不这么磨磨唧唧,赶紧立马撒冷的!!

小屌丝:就是,能不能帮我给pdf文件加个水印…

小鱼:就这…

小屌丝:对,就这!


小鱼:别整这么无辜又可爱的小表情。

小屌丝:谁曾经还不是个小可爱 ^ ^

小鱼:我擦,破防了,我整还不行嘛!

小屌丝:奈斯 ~ ~


今天我们就来分享 pdf文档如何添加水印。

小鱼分享过图片添加水印的方法,很简单,直接watermark模块的add_watermark 就可以,


如果不知道的,可以看这篇《Python3,2行代码添加水印,发朋友圈,图片再也不怕被盗了!!!》


但是,pdf文件添加水印,就需要用到另外两个库,即:


reportlab

pikepdf

这两个库有什么特殊的"魔法",可以给pdf添加水印呢?

别走开,稍后回来!


2、指定水印内容输出到pdf文件


2.1 模块安装


因为reportlab库是python的第三方库,所以,

第一步,安装:


pip install reportlab


其他方式安装:


《Python3,选择Python自动安装第三方库,从此跟pip说拜拜!!》

《Python3:我低调的只用一行代码,就导入Python所有库!!》


2.2 思路

1、要设置水印字体填充:

所以,我们就需要对字体设置一些基本信息,例如:


content: 水印文本内容

filename: 导出的水印文件名

width: 画布宽度,单位:mm

height: 画布高度,单位:mm

font: 对应注册的字体代号

fontsize: 字号大小

angle: 旋转角度

text_stroke_color_rgb: 文字轮廓rgb色

text_fill_color_rgb: 文字填充rgb色

text_fill_alpha: 文字透明度

2、输出水印字体到pdf文档

canvas.Canvas.save()方法,把输出的字体保存到pdf文档


2.3 代码示例


直接上代码:


# -*- coding:utf-8 -*-
# @Time   : 2022-02-10
# @Author : carl_DJ
from typing import Union,Tuple
from reportlab.lib import units
from reportlab.pdfgen import canvas
from reportlab.pdfbase import pdfmetrics
from reportlab.pdfbase.ttfonts import  TTFont
pdfmetrics.registerFont(TTFont('msyh',r'./msyh.ttc'))
'''
用于生成包含content文字内容的水印pdf文件
content: 水印文本内容
filename: 导出的水印文件名
width: 画布宽度,单位:mm
height: 画布高度,单位:mm
font: 对应注册的字体代号
fontsize: 字号大小
angle: 旋转角度
text_stroke_color_rgb: 文字轮廓rgb色
text_fill_color_rgb: 文字填充rgb色
text_fill_alpha: 文字透明度
'''
def create_wartmark(content:str,
                    filename:str,
                    width: Union[int, float],
                    height: Union[int, float],
                    font: str,
                    fontsize: int,
                    angle: Union[int, float] = 45,
                    text_stroke_color_rgb: Tuple[int, int, int] = (0, 0, 0),
                    text_fill_color_rgb: Tuple[int, int, int] = (0, 0, 0),
                    text_fill_alpha: Union[int, float] = 1) -> None:
    #创建PDF文件,指定文件名及尺寸,以像素为单位
    c = canvas.Canvas(f'{filename}.pdf',pagesize=(width*units.mm,height*units.mm))
    #画布平移保证文字完整性
    c.translate(0.1*width*units.mm,0.1*height*units.mm)
    #设置旋转角度
    c.rotate(angle)
    #设置字体大小
    c.setFont(font,fontsize)
    #设置字体轮廓彩色
    c.setStrokeColorRGB(*text_stroke_color_rgb)
    #设置填充色
    c.setFillColorRGB(*text_fill_color_rgb)
    #设置字体透明度
    c.setFillAlpha(text_fill_alpha)
    #绘制字体内容
    c.drawString(0,0,content)
    #保存文件
    c.save()
create_wartmark(content='关注carl_奕然,学习更多有趣的python知识',
                 filename='小鱼watermarkDemo',
                 width=200,
                 height=200,
                 font='msyh',
                 fontsize=35,
                 text_fill_alpha=0.3)

 

运行结果:

image.png


3、水印内容批量输出到pdf文件


3.1 模块安装


因为pikepdf库是python的第三方库,所以,

第一步,安装:


pip install pikepdf

1

其他方式安装:


《Python3,选择Python自动安装第三方库,从此跟pip说拜拜!!》

《Python3:我低调的只用一行代码,就导入Python所有库!!》


小屌丝:鱼哥,为什么我们还需要安装pikepdf这个模块?

小鱼:因为我们要把已生成的pdf水印覆盖到目标pdf文档。

小屌丝:你的意思是,上面的代码,就仅仅是生成一个水印文档,其他的没有了?

小鱼:对的,你可以使用上面已生成的pdf水印文档,也可以随便找一个pdf文档作为水印文档,去覆盖到目标pdf文档。

小屌丝:还可以这么玩?

小鱼:对的,待会给你演示。


3.2 思路


1、需要准备pdf文件:


目标pdf文件

已生成水印的pdf文件

2、我们把已生成的pdf文档来覆盖到目标pdf文档,同样,需要设置的参数:


target_pdf_path:目标pdf文件路径+文件名

watermark_pad_path:水印pdf文件路径+文件名

nrow:水印平铺的行数

ncol:水印平铺的列数

skip_pages:需要跳过不添加水印的页数

目标pdf文档:

image.png

3.3 代码示例


# -*- coding:utf-8 -*-
# @Time   : 2022-02-10
# @Author : carl_DJ
from typing import List
from pikepdf import Pdf,Page,Rectangle
'''
向目标pdf文件批量添加水印
target_pdf_path:目标pdf文件路径+文件名
watermark_pad_path:水印pdf文件路径+文件名
nrow:水印平铺的行数
ncol:水印平铺的列数
skip_pages:需要跳过不添加水印的页数
'''
def add_watemark(target_pdf_path:str,
                 watermark_pdf_path:str,
                 nrow:int,
                 ncol:int,
                 skip_pages:List[int] = []) -> None:
    #选择需要添加水印的pdf文件
    target_pdf = Pdf.open(target_pdf_path)
    #读取水印pdf文件并提取水印
    watermark_pdf = Pdf.open(watermark_pdf_path)
    watermark_page = watermark_pdf.pages[0]
    #遍历目标pdf文件中的所有页,批量添加水印
    for idx,target_page in enumerate(target_pdf.pages):
        for x in range(ncol):
            for y in range(nrow):
                #向目标页指定范围添加水印
                target_page.add_overlay(watermark_page,
                                        Rectangle(target_page.trimbox[2] * x / ncol,
                                        target_page.trimbox[3] * y / nrow,
                                        target_page.trimbox[2] * (x + 1) / ncol,
                                        target_page.trimbox[3] * (y + 1) / nrow
                                        ))
    #保存PDF文件,同时对pdf文件进行重命名,从文件名第7位置写入后缀名
    target_pdf.save(target_pdf_path[:6] + '_已添加水印.pdf')
add_watemark(target_pdf_path='跟小鱼学水印.pdf',
             #把生成的水印示例,添加到目标水印文件中
             watermark_pdf_path='小鱼watermarkDemo.pdf',
             nrow = 3,
             ncol = 2 ,
             skip_pages= [0])


运行结果:

image.png


4、总结


写到这里,今天的分享就差不多快结束了。

今天主要是对reportlab 库和pikepdf库进行了拓展,让添加水印,不在花钱。


关注小鱼博客,学习更多更有趣python知识。


目录
相关文章
|
9天前
|
机器学习/深度学习 存储 算法
解锁文件共享软件背后基于 Python 的二叉搜索树算法密码
文件共享软件在数字化时代扮演着连接全球用户、促进知识与数据交流的重要角色。二叉搜索树作为一种高效的数据结构,通过有序存储和快速检索文件,极大提升了文件共享平台的性能。它依据文件名或时间戳等关键属性排序,支持高效插入、删除和查找操作,显著优化用户体验。本文还展示了用Python实现的简单二叉搜索树代码,帮助理解其工作原理,并展望了该算法在分布式计算和机器学习领域的未来应用前景。
|
10天前
|
人工智能 编解码 文字识别
OCRmyPDF:16.5K Star!快速将 PDF 文件转换为可搜索、可复制的文档的命令行工具
OCRmyPDF 是一款开源命令行工具,专为将扫描的 PDF 文件转换为可搜索、可复制的文档。支持多语言、图像优化和多核处理。
134 17
OCRmyPDF:16.5K Star!快速将 PDF 文件转换为可搜索、可复制的文档的命令行工具
|
6天前
|
文字识别 BI
【图片型PDF】批量识别扫描件PDF指定区域局部位置内容,将识别内容导出Excel表格或批量改名文件,基于阿里云OCR对图片型PDF识别改名案例实现
在医疗和政务等领域,图片型PDF文件(如病历、报告、公文扫描件)的处理需求广泛。通过OCR技术识别这些文件中的文字信息,提取关键内容并保存为表格,极大提高了信息管理和利用效率。本文介绍一款工具——咕嘎批量OCR系统,帮助用户快速处理图片型PDF文件,支持区域识别、内容提取、导出表格及批量改名等功能。下载工具后,按步骤选择处理模式、进行区域采样、批量处理文件,几分钟内即可高效完成数百个文件的处理。
40 8
|
26天前
|
机器学习/深度学习 人工智能 文字识别
Zerox:AI驱动的万能OCR工具,精准识别复杂布局并输出Markdown格式,支持PDF、DOCX、图片等多种文件格式
Zerox 是一款开源的本地化高精度OCR工具,基于GPT-4o-mini模型,支持PDF、DOCX、图片等多种格式文件,能够零样本识别复杂布局文档,输出Markdown格式结果。
103 4
Zerox:AI驱动的万能OCR工具,精准识别复杂布局并输出Markdown格式,支持PDF、DOCX、图片等多种文件格式
|
20天前
|
监控 网络安全 开发者
Python中的Paramiko与FTP文件夹及文件检测技巧
通过使用 Paramiko 和 FTP 库,开发者可以方便地检测远程服务器上的文件和文件夹是否存在。Paramiko 提供了通过 SSH 协议进行远程文件管理的能力,而 `ftplib` 则提供了通过 FTP 协议进行文件传输和管理的功能。通过理解和应用这些工具,您可以更加高效地管理和监控远程服务器上的文件系统。
49 20
|
26天前
|
存储 数据采集 数据处理
如何在Python中高效地读写大型文件?
大家好,我是V哥。上一篇介绍了Python文件读写操作,今天聊聊如何高效处理大型文件。主要方法包括:逐行读取、分块读取、内存映射(mmap)、pandas分块处理CSV、numpy处理二进制文件、itertools迭代处理及linecache逐行读取。这些方法能有效节省内存,提升效率。关注威哥爱编程,学习更多Python技巧。
|
9月前
|
算法 编译器 开发者
如何提高Python代码的性能:优化技巧与实践
本文探讨了如何提高Python代码的性能,重点介绍了一些优化技巧与实践方法。通过使用适当的数据结构、算法和编程范式,以及利用Python内置的性能优化工具,可以有效地提升Python程序的执行效率,从而提升整体应用性能。本文将针对不同场景和需求,分享一些实用的优化技巧,并通过示例代码和性能测试结果加以说明。
|
5月前
|
人工智能 数据挖掘 数据处理
揭秘Python编程之美:从基础到进阶的代码实践之旅
【9月更文挑战第14天】本文将带领读者深入探索Python编程语言的魅力所在。通过简明扼要的示例,我们将揭示Python如何简化复杂问题,提升编程效率。无论你是初学者还是有一定经验的开发者,这篇文章都将为你打开一扇通往高效编码世界的大门。让我们开始这段充满智慧和乐趣的Python编程之旅吧!
|
3月前
|
机器学习/深度学习 数据采集 人工智能
探索机器学习:从理论到Python代码实践
【10月更文挑战第36天】本文将深入浅出地介绍机器学习的基本概念、主要算法及其在Python中的实现。我们将通过实际案例,展示如何使用scikit-learn库进行数据预处理、模型选择和参数调优。无论你是初学者还是有一定基础的开发者,都能从中获得启发和实践指导。
88 2
|
4月前
|
大数据 Python
Python 高级编程:深入探索高级代码实践
本文深入探讨了Python的四大高级特性:装饰器、生成器、上下文管理器及并发与并行编程。通过装饰器,我们能够在不改动原函数的基础上增添功能;生成器允许按需生成值,优化处理大数据;上下文管理器确保资源被妥善管理和释放;多线程等技术则助力高效完成并发任务。本文通过具体代码实例详细解析这些特性的应用方法,帮助读者提升Python编程水平。
205 5

热门文章

最新文章