水印技术是保护文档安全、声明所有权及防止未经授权复制的关键手段。无论是分发草稿还是为最终交付成果添加品牌标识,使用水印都能有效保护您的内容。本教程将指导您如何使用 Spire.PDF for Python 在 Python 中为 PDF 文件添加水印 。
我们将逐步演示如何插入文字水印与图片水印、调整透明度与定位,并解决常见问题——所有步骤均配有清晰且注释完善的代码示例。
Python PDF 水印处理库
Spire.PDF for Python 是一款功能强大的 PDF 处理库,特别针对水印功能提供以下特性:
- 精准定位 :支持高精度水印定位与旋转
- 透明度调节 :灵活的透明度控制选项
- 多格式支持 :可添加文字或图片水印
- 灵活应用 :支持单页或整份文档的水印添加
- 无损质量 :保持原始 PDF 文件质量
开始前请确保已通过以下命令安装库:
pip install spire.pdf
添加文字水印到 PDF
以下代码演示如何为 PDF 每页添加倾斜的"禁止复制"文字水印,包含字号、颜色、位置、旋转角度及透明度的专业级设置:
from spire.pdf import *
from spire.pdf.common import *
import math
# 创建PdfDocument类的对象
doc = PdfDocument()
# 从指定路径加载PDF文档
doc.LoadFromFile("C:\\Users\\Administrator\\Desktop\\Input.pdf")
# 为水印字体创建PdfTrueTypeFont类的对象
font = PdfTrueTypeFont("黑体", 48.0, 0, True)
# 指定水印文本
text = "禁 止 复 制"
# 测量文本的尺寸以确保正确定位
text_width = font.MeasureString(text).Width
text_height = font.MeasureString(text).Height
# 循环遍历文档中的每一页
for i in range(doc.Pages.Count):
# 获取当前页面
page = doc.Pages.get_Item(i)
# 保存当前画布状态
state = page.Canvas.Save()
# 计算页面的中心坐标
x = page.Canvas.Size.Width / 2
y = page.Canvas.Size.Height / 2
# 将坐标系平移到中心,使页面的中心成为原点(0, 0)
page.Canvas.TranslateTransform(x, y)
# 将画布逆时针旋转45度以显示水印
page.Canvas.RotateTransform(-45.0)
# 设置水印的透明度
page.Canvas.SetTransparency(0.4)
# 使用负偏移量在中心位置绘制水印文本
page.Canvas.DrawString(text, font, PdfBrushes.get_Blue(), PointF(-text_width / 2, -text_height / 2))
# 恢复画布状态,以防止变换影响后续绘图
page.Canvas.Restore(state)
# 将修改后的文档保存到新的PDF文件
doc.SaveToFile("output/TextWatermark.pdf")
# 释放资源
doc.Dispose()
代码解析:
- 加载 PDF 文档 :通过 PdfDocument 类从指定路径加载待处理的 PDF 文件。
- 配置水印文本 :设置水印文字内容("禁 止 复 制"),并指定字体(黑体,48磅字号),同时测量文本尺寸以实现精准定位。
- 应用图形变换 :针对每个页面执行以下操作:
- 将坐标系原点移至页面中心
- 画布逆时针旋转45度
- 设置水印透明度为40%
- 绘制水印 :在坐标(-text_width/2, -text_height/2)处绘制文本,该计算确保无论画布如何旋转,文字始终以页面中心为基准对称分布。
- 保存文档 :将处理后的文档另存为新 PDF 文件。
效果图:
添加图片水印到 PDF
以下代码演示如何为PDF每一页添加半透明图片水印,确保精准定位并呈现专业视觉效果。
from spire.pdf import *
from spire.pdf.common import *
# 创建PdfDocument类的对象
doc = PdfDocument()
# 从指定路径加载PDF文档
doc.LoadFromFile("C:\\Users\\Administrator\\Desktop\\Input.pdf")
# 从指定路径加载水印图像
image = PdfImage.FromFile("C:\\Users\\Administrator\\Desktop\\logo.png")
# 获取加载的图像的宽度和高度以进行定位
imageWidth = float(image.Width)
imageHeight = float(image.Height)
# 循环遍历文档中的每一页以应用水印
for i in range(doc.Pages.Count):
# 获取当前页面
page = doc.Pages.get_Item(i)
# 将水印的透明度设置为50%
page.Canvas.SetTransparency(0.5)
# 获取当前页面的尺寸
pageWidth = page.ActualSize.Width
pageHeight = page.ActualSize.Height
# 计算x和y坐标以将图像居中放置在页面上
x = (pageWidth - imageWidth) / 2
y = (pageHeight - imageHeight) / 2
# 在计算出的中心位置绘制图像
page.Canvas.DrawImage(image, x, y, imageWidth, imageHeight)
# 将修改后的文档保存到新的PDF文件
doc.SaveToFile("output/ImageWatermark.pdf")
# 释放资源
doc.Dispose()
代码解析:
- 加载 PDF 文档 :通过PdfDocument类从指定路径加载需要添加水印的PDF文件。
- 配置水印图片: 从指定路径加载水印图片文件,并获取图片尺寸参数以实现精确定位。
- 应用图像处理 :对每个页面执行以下操作:
- 设置水印透明度为50%
- 计算页面中心坐标作为水印位置基准
- 绘制水印图像 :根据计算出的中心坐标绘制水印图片,确保在每页居中显示。
- 保存文档 :将添加水印后的文档另存为新的PDF文件。
效果图:
除了水印之外,您还可以为 PDF 添加图章。与水印固定位置不同,图章可以自由移动或删除,为文档批注提供了更大的灵活性。
常见问题排查
- 水印未显示:
- 检查文件路径是否正确
- 确认透明度未设置为0(完全透明)
- 确保水印坐标位于页面边界内
- 质量问题:
- 文字水印建议使用更高质量的字体
- 图片水印需确保足够的分辨率
- 旋转异常:
- 注意旋转是围绕当前原点进行的
- 变换顺序很重要(先平移后旋转)
总结
借助 Spire.PDF for Python 库,为 PDF 文档添加水印既简单便捷又功能强大。您既可以批量添加醒目的"机密"警示水印,也能嵌入品牌 Logo 作为优雅的背景标识。该库支持灵活的坐标定位、透明度调节、旋转等高级功能,让您能够根据文档类型和使用场景,轻松打造专业级的水印解决方案。
问答集锦
Q1. 能否在同一个PDF中同时添加文字和图片水印?
可以,您只需在遍历PDF页面的循环中结合使用两种水印添加方法即可。
Q2. 如何旋转图片水印?
与文字水印示例类似,在绘制图片前使用 Canvas.RotateTransform( 角度) 方法即可实现旋转。
Q3. Spire.PDF是否支持透明PNG作为水印?
支持。当使用PNG图片作为水印时,Spire.PDF会保留其原有的透明度。
Q4. 能否为不同页面添加不同的水印?
完全可以。您可以在页面循环中添加条件判断逻辑,根据页码或其他标准为不同页面应用不同的水印。
申请临时License
如果您需要去除生成文档中的评估提示或解除功能限制,请该Email地址已收到反垃圾邮件插件保护。要显示它您需要在浏览器中启用JavaScript。获取有效期 30 天的临时许可证。