找回密码
 立即注册
首页 业界区 业界 国产化PDF处理控件Spire.PDF教程:如何使用 Python 添加 ...

国产化PDF处理控件Spire.PDF教程:如何使用 Python 添加水印到 PDF

嫂潍 昨天 23:00
1.png

水印技术是保护文档安全、声明所有权及防止未经授权复制的关键手段。无论是分发草稿还是为最终交付成果添加品牌标识,使用水印都能有效保护您的内容。E-iceblue旗下Spire系列产品是国产文档处理领域的优秀产品,支持国产化信创,帮助企业高效构建文档处理的应用程序。本教程将指导您如何使用 Spire.PDF for Python 在 Python 中为 PDF 文件添加水印 。
我们将逐步演示如何插入文字水印与图片水印、调整透明度与定位,并解决常见问题——所有步骤均配有清晰且注释完善的代码示例。
Spire.PDF for Python免费试用下载 ,请联系Spire官方授权代理商慧都科技
加入Spire技术交流QQ群(125237868),与更多开发者一起提升文档开发技能。
Python PDF 水印处理库

Spire.PDF for Python 是一款功能强大的 PDF 处理库,特别针对水印功能提供以下特性:

  • 精准定位 :支持高精度水印定位与旋转
  • 透明度调节 :灵活的透明度控制选项
  • 多格式支持 :可添加文字或图片水印
  • 灵活应用 :支持单页或整份文档的水印添加
  • 无损质量 :保持原始 PDF 文件质量
开始前请确保已通过以下命令安装库:
  1. pip install spire.pdf
复制代码
Spire.PDF for Python免费试用下载 ,请联系Spire官方授权代理商慧都科技
加入Spire技术交流QQ群(125237868),与更多开发者一起提升文档开发技能。
添加文字水印到 PDF

以下代码演示如何为 PDF 每页添加倾斜的"禁止复制"文字水印,包含字号、颜色、位置、旋转角度及透明度的专业级设置:
  1. from spire.pdf import *
  2. from spire.pdf.common import *
  3. import math
  4. # 创建PdfDocument类的对象
  5. doc = PdfDocument()
  6. # 从指定路径加载PDF文档
  7. doc.LoadFromFile("C:\\Users\\Administrator\\Desktop\\Input.pdf")
  8. # 为水印字体创建PdfTrueTypeFont类的对象
  9. font = PdfTrueTypeFont("黑体", 48.0, 0, True)
  10. # 指定水印文本
  11. text = "禁 止 复 制"
  12. # 测量文本的尺寸以确保正确定位
  13. text_width = font.MeasureString(text).Width
  14. text_height = font.MeasureString(text).Height
  15. # 循环遍历文档中的每一页
  16. for i in range(doc.Pages.Count):
  17.     # 获取当前页面
  18.     page = doc.Pages.get_Item(i)
  19.    
  20.     # 保存当前画布状态
  21.     state = page.Canvas.Save()
  22.     # 计算页面的中心坐标
  23.     x = page.Canvas.Size.Width  / 2
  24.     y = page.Canvas.Size.Height / 2
  25.     # 将坐标系平移到中心,使页面的中心成为原点(0, 0)
  26.     page.Canvas.TranslateTransform(x, y)
  27.    
  28.     # 将画布逆时针旋转45度以显示水印
  29.     page.Canvas.RotateTransform(-45.0)
  30.     # 设置水印的透明度
  31.     page.Canvas.SetTransparency(0.4)
  32.    
  33.     # 使用负偏移量在中心位置绘制水印文本
  34.     page.Canvas.DrawString(text, font, PdfBrushes.get_Blue(), PointF(-text_width / 2, -text_height / 2))
  35.    
  36.     # 恢复画布状态,以防止变换影响后续绘图
  37.     page.Canvas.Restore(state)
  38. # 将修改后的文档保存到新的PDF文件
  39. doc.SaveToFile("output/TextWatermark.pdf")
  40. # 释放资源
  41. doc.Dispose()
复制代码
代码解析:

  • 加载 PDF 文档 :通过 PdfDocument 类从指定路径加载待处理的 PDF 文件。
  • 配置水印文本 :设置水印文字内容("禁 止 复 制"),并指定字体(黑体,48磅字号),同时测量文本尺寸以实现精准定位。
  • 应用图形变换 :针对每个页面执行以下操作:

    • 将坐标系原点移至页面中心
    • 画布逆时针旋转45度
    • 设置水印透明度为40%

  • 绘制水印 :在坐标(-text_width/2, -text_height/2)处绘制文本,该计算确保无论画布如何旋转,文字始终以页面中心为基准对称分布。
  • 保存文档 :将处理后的文档另存为新 PDF 文件。
效果图:
2.png

添加图片水印到 PDF

以下代码演示如何为PDF每一页添加半透明图片水印,确保精准定位并呈现专业视觉效果。
  1. from spire.pdf import *
  2. from spire.pdf.common import *
  3. # 创建PdfDocument类的对象
  4. doc = PdfDocument()
  5. # 从指定路径加载PDF文档
  6. doc.LoadFromFile("C:\\Users\\Administrator\\Desktop\\Input.pdf")
  7. # 从指定路径加载水印图像
  8. image = PdfImage.FromFile("C:\\Users\\Administrator\\Desktop\\logo.png")
  9. # 获取加载的图像的宽度和高度以进行定位
  10. imageWidth = float(image.Width)
  11. imageHeight = float(image.Height)
  12. # 循环遍历文档中的每一页以应用水印
  13. for i in range(doc.Pages.Count):
  14.     # 获取当前页面
  15.     page = doc.Pages.get_Item(i)
  16.     # 将水印的透明度设置为50%
  17.     page.Canvas.SetTransparency(0.5)
  18.     # 获取当前页面的尺寸
  19.     pageWidth = page.ActualSize.Width
  20.     pageHeight = page.ActualSize.Height
  21.     # 计算x和y坐标以将图像居中放置在页面上
  22.     x = (pageWidth - imageWidth) / 2
  23.     y = (pageHeight - imageHeight) / 2
  24.     # 在计算出的中心位置绘制图像
  25.     page.Canvas.DrawImage(image, x, y, imageWidth, imageHeight)
  26. # 将修改后的文档保存到新的PDF文件
  27. doc.SaveToFile("output/ImageWatermark.pdf")
  28. # 释放资源
  29. doc.Dispose()
复制代码
代码解析:

  • 加载 PDF 文档 :通过PdfDocument类从指定路径加载需要添加水印的PDF文件。
  • 配置水印图片: 从指定路径加载水印图片文件,并获取图片尺寸参数以实现精确定位。
  • 应用图像处理 :对每个页面执行以下操作:

    • 设置水印透明度为50%
    • 计算页面中心坐标作为水印位置基准

  • 绘制水印图像 :根据计算出的中心坐标绘制水印图片,确保在每页居中显示。
  • 保存文档 :将添加水印后的文档另存为新的PDF文件。
效果图:
3.png

除了水印之外,您还可以为 PDF 添加图章。与水印固定位置不同,图章可以自由移动或删除,为文档批注提供了更大的灵活性。
常见问题排查


  • 水印未显示:

    • 检查文件路径是否正确
    • 确认透明度未设置为0(完全透明)
    • 确保水印坐标位于页面边界内

  • 质量问题:

    • 文字水印建议使用更高质量的字体
    • 图片水印需确保足够的分辨率

  • 旋转异常:

    • 注意旋转是围绕当前原点进行的
    • 变换顺序很重要(先平移后旋转)

总结

借助 Spire.PDF for Python 库,为 PDF 文档添加水印既简单便捷又功能强大。您既可以批量添加醒目的"机密"警示水印,也能嵌入品牌 Logo 作为优雅的背景标识。该库支持灵活的坐标定位、透明度调节、旋转等高级功能,让您能够根据文档类型和使用场景,轻松打造专业级的水印解决方案。
问答集锦

Q1. 能否在同一个PDF中同时添加文字和图片水印?

可以,您只需在遍历PDF页面的循环中结合使用两种水印添加方法即可。
Q2. 如何旋转图片水印?

与文字水印示例类似,在绘制图片前使用 Canvas.RotateTransform( 角度) 方法即可实现旋转。
Q3. Spire.PDF是否支持透明PNG作为水印?

支持。当使用PNG图片作为水印时,Spire.PDF会保留其原有的透明度。
Q4. 能否为不同页面添加不同的水印?

完全可以。您可以在页面循环中添加条件判断逻辑,根据页码或其他标准为不同页面应用不同的水印。
Spire.PDF for Python免费试用下载 ,请联系Spire官方授权代理商慧都科技
加入Spire技术交流QQ群(125237868),与更多开发者一起提升文档开发技能。

来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
您需要登录后才可以回帖 登录 | 立即注册