Python 在PDF中添加条形码、二维码

在PDF中添加条码是一个常见需求,特别是在需要自动化处理、跟踪或检索PDF文件时。作为一种机器可读的标识符,PDF中的条码可以包含各种类型的信息,如文档的唯一标识、版本号、日期等。以下是一篇关于如何使用Python在PDF中添加条形码或二维码的文章。

所需Python库

Spire.PDF for Python 库:用于在PDF文件中直接绘制条形码,支持多种一维条码类型,如 Codabar, Code11, Code32, Code39, Code93等。
由于Spire.PDF for Python只支持创建一维条码,如果需要在PDF中添加二维码,我们还需要结合Spire.Barcode for Python库。

这两个Python库可以通过下面的pip 命令进行安装:

pip install Spire.Pdf
pip install Spire.Barcode

Python 在PDF 文档中添加条形码

Spire.PDF for Python库提供了不同的类来代表不同的一维条码类型,该示例将演示如何使用该库在PDF中绘制常见的Codabar和Code39条码。

主要步骤:

  1. 新建PDF文档并添加页面;
  2. 在PDF页面上绘制文本;
  3. 创建 PdfCodabarBarcode 对象,然后使用其 Draw()方法将Codabar条码绘制到页面指定位置
  4. 创建 PdfCode39Barcode 对象,然后使用其Draw()方法将Code39条码绘制到页面指定位置
  5. 保存PDF文件。

Python 代码:

from spire.pdf.common import *
from spire.pdf import *

# 创建PDF文件
pdf = PdfDocument()
# 添加页面
page = pdf.Pages.Add(PdfPageSize.A4())

y = 20.0
# 在页面上绘制文本
font = PdfTrueTypeFont("Arial", 12.0, PdfFontStyle.Bold, True)
text = PdfTextWidget()
text.Font = font
text.Text = "Codabar:"
result = text.Draw(page, 0.0, y)
page = result.Page
y = result.Bounds.Bottom + 2

# 创建PdfCodabarBarcode对象,并将Codabar条码绘制到页面上
Codabar = PdfCodabarBarcode("00:12-3456/7890")
Codabar.BarcodeToTextGapHeight = 1.0
Codabar.EnableCheckDigit = True
Codabar.ShowCheckDigit = True
Codabar.TextDisplayLocation = TextLocation.Bottom
Codabar.TextColor = PdfRGBColor(Color.get_Green())
Codabar.Draw(page, PointF(0.0, y))
y = Codabar.Bounds.Bottom + 8

# 在页面上绘制文本
text.Text = "Code39:"
result = text.Draw(page, 0.0, y)
page = result.Page
y = result.Bounds.Bottom + 2

# 创建PdfCode39Barcode对象,并将Code39条码绘制到页面上
Code39 = PdfCode39Barcode("ABC-012689")
Code39.BarcodeToTextGapHeight = 1.0
Code39.TextDisplayLocation = TextLocation.Bottom
Code39.TextColor = PdfRGBColor(Color.get_Green())
Code39.Draw(page, PointF(0.0, y))

# 保存PDF文档
pdf.SaveToFile("PDF中添加条形码.pdf")
pdf.Close()

生成条形码:
Python在PDF中添加条形码

Python 在PDF文档中添加二维码

该示例中我们需要先借助Spire.Barcode for Python库来生成二维码图片,然后再使用Spire.PDF for Python库将二维码图片绘制到PDF页面上。

主要步骤:

  1. 使用Python条码库生成二维码图片;
    • 创建 BarcodeSettings 对象,然后使用其Type属性将条码类型设置为二维码QRCode
    • 设置二维码的数据、宽度、纠错级别、以及是否显示文本等
    • 基于以上设置创建 BarCodeGenerator 对象,然后使用其 GenerateImage() 方法生成二维码图片
  2. 将生成的二维码图片保存为PNG图片;
  3. 使用Python PDF库将二维码图片绘制到PDF中;
    • 创建PDF文档,并添加一页
    • 加载二维码图片,然后使用 DrawImage() 方法将二维码绘制到PDF页面指定位置处
  4. 保存PDF文档。

Python 代码:

from spire.pdf.common import *
from spire.pdf import *
from spire.barcode import *

# 创建BarcodeSettings对象
settings = BarcodeSettings()

# 设置条码类型为QRCode
settings.Type = BarCodeType.QRCode
# 设置条码数据、宽度、纠错级别等
settings.Data = "ABCD12345"
settings.Data2D = "ABCD12345"
settings.X = 2
settings.QRCodeECL = QRCodeECL.M
settings.ShowTextOnBottom = True

# 生成二维码图片
barCodeGenerator = BarCodeGenerator(settings)
QRimage = barCodeGenerator.GenerateImage()

# 将二维码图片保存为PNG文件
with open("QRCode.png", "wb") as file:
    file.write(QRimage)

# 创建PDF文档
pdf = PdfDocument()
# 添加页面
page = pdf.Pages.Add()

# 将二维码图片绘制到PDF页面上
pdfImage = PdfImage.FromFile("QRCode.png")
page.Canvas.DrawImage(pdfImage, 0.0, 20.0)

# 保存PDF文档
pdf.SaveToFile("Pdf中添加二维码.pdf")
pdf.Close()

生成二维码:
Python在PDF中添加二维码

Spire.Barcode for Python库支持几十种一维和二维条码类型,因此对于其他Spire.PDF for Python库不支持的一维条形码,我们也可以参考示例二提供的方法结合使用这两个库,先生成指定条码图片,再绘制到PDF页面上。


对于生成文档中的警告信息,可以点击自行申请一个月免费授权试用:https://www.e-iceblue.cn/misc/temporary-license.html

  • 5
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以使用 Python 的 `pdfminer` 库来提取 PDF 文件的文本,然后使用 `pyzbar` 库来识别二维码。以下是一个示例代码: ```python import io import pdfminer import pyzbar.pyzbar as pyzbar from PIL import Image # 从 PDF 文件提取文本 def extract_text_from_pdf(pdf_file): output = io.StringIO() with open(pdf_file, 'rb') as f: parser = pdfminer.pdfparser.PDFParser(f) doc = pdfminer.pdfdocument.PDFDocument(parser) for page in pdfminer.pdfinterp.PDFPageInterpreter(pdfminer.pdfinterp.PDFResourceManager(), pdfminer.pdfinterp.PDFPageInterpreter): page_resource_manager = pdfminer.pdfinterp.PDFResourceManager() device = pdfminer.pdfdevice.TagExtractor(page_resource_manager, outfp=output, laparams=None) interpreter = pdfminer.pdfinterp.PDFPageInterpreter(page_resource_manager, device) interpreter.process_page(page) return output.getvalue() # 在图像查找二维码 def find_qr_codes(image_file): img = Image.open(image_file) codes = pyzbar.decode(img) return [code.data.decode('utf-8') for code in codes if code.type == 'QRCODE'] # 从 PDF 文件查找二维码 def find_qr_codes_in_pdf(pdf_file): text = extract_text_from_pdf(pdf_file) codes = [] for line in text.split('\n'): codes += find_qr_codes(line.strip()) return codes # 示例用法 pdf_file = 'example.pdf' codes = find_qr_codes_in_pdf(pdf_file) print(codes) ``` 这个示例代码假设 PDF 文件的每行文本都是一个二维码。它首先使用 `pdfminer` 库提取 PDF 文件的文本,然后使用 `pyzbar` 库在其查找二维码。对于每个找到的二维码,它将其解码并将其作为字符串添加到结果列表
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值