彩票走势图

PDF处理控件pdf功能演示:在 C# 中从 PDF 读取条形码

翻译|使用教程|编辑:胡涛|2022-09-22 11:05:24.860|阅读 287 次

概述:本文将为你介绍如何在 C# 中从 PDF 读取条形码,欢迎查阅~

# 慧都年终大促·界面/图表报表/文档/IDE等千款热门软控件火热促销中 >>

相关链接:

Aspose.PDF 是一款高级PDF处理API,可以在跨平台应用程序中轻松生成,修改,转换,呈现,保护和打印文档。无需使用Adobe Acrobat。此外,API提供压缩选项,表创建和处理,图形和图像功能,广泛的超链接功能,图章和水印任务,扩展的安全控件和自定义字体处理。本文将为你介绍如何在 C# 中从 PDF 读取条形码

Aspose.pdf 最新下载

我们可以生成条形码并将其添加到PDF文档中,如我之前的帖子中所述。在某些情况下,我们可能需要以编程方式检测和读取嵌入到 PDF 文档中的条形码。它有助于解码 PDF 文档(如发票、收据或报告)中的条形码和二维码形式的嵌入信息。在本文中,我们将学习如何使用 C# 从 PDF 文档中读取条形码。

1、C# API 从 PDF 读取条形码

我们将按照两步程序从 PDF 文档中读取条形码。首先,我们将使用Aspose.PDF for .NET API 加载 PDF 文档,然后将其页面渲染为光栅图像。之后,我们将使用Aspose.BarCode for .NET API 从渲染图像中读取条形码。

请下载 API 的 DLL或使用NuGet安装它。

PM> Install-Package Aspose.BarCode
PM> Install-Package Aspose.PDF
2、使用 C# 从 PDF 读取条形码

Aspose.PDF API的类代表一个 PDF 文档。API的函数将 PDF 页面呈现为 PNG 内存流。Aspose.BarCode API的类使我们能够执行操作来检测条形码。BarCodeResult类存储检测的条码信息,例如条码类型、代码文本、区域和其他参数。

我们可以按照以下步骤读取嵌入在 PDF 文档任何页面上的条形码图像:

  1. 首先,使用Document类加载 PDF 文档。
  2. 接下来,遍历所有页面并将它们呈现到内存流中。
  3. 然后,使用流对象创建BarCodeReader类的实例。
  4. 之后,调用ReadBarCodes()方法获取BarCodeResult对象。
  5. 最后,显示条码信息。

以下代码示例展示了如何使用 C# 从 PDF 文档中读取条形码

// This code example demonstrates how to read a barcode from a PDF document using C#.
// The path to the document
string file = @"C:\Files\BarCode\sample-PDF-with-Barcodes.pdf";

// Load a PDF document
Aspose.Pdf.Document pdfDoc = new Aspose.Pdf.Document(file);

// Proceed all PDF pages starting from page 1
for (int i = 1; i <= pdfDoc.Pages.Count; ++i)
{
// Render PDF page to the stream
MemoryStream ms = pdfDoc.Pages[i].ConvertToPNGMemoryStream();
ms.Position = 0;

// Recognize barcodes from the rendered image of the page
BarCodeReader reader = new BarCodeReader(ms);

// Show results
foreach (BarCodeResult result in reader.ReadBarCodes())
{
Console.WriteLine("Codetext found: " + result.CodeText);
Console.WriteLine("Symbology: " + result.CodeType);
Console.WriteLine("-------------------------------");
}
}

Codetext found: Aspose.Barcode Pdf417 Example
Symbology: Pdf417
-------------------------------
Codetext found: Aspose.Barcode QR Example
Symbology: QR
-------------------------------
Codetext found: Aspose.Barcode DataMatrix Example
Symbology: DataMatrix
-------------------------------

请下载本博文中使用的带有条形码的输入 PDF 文档。

3、使用 C# 将 PDF 转换为图像并读取条形码

类将 PDF 页面转换为图像来从 PDF 文档中读取条形码。它允许将PDF文件的每一页转换为图像,然后我们将从转换后的图像中读取条形码信息。

我们可以按照以下步骤从转换后的 PDF 页面中读取条形码:

  1. 首先,使用Document类加载 PDF 文档。
  2. 接下来,创建PdfConverter类的实例。
  3. (可选)设置呈现选项,例如BarcodeOptimization
  4. 然后,设置图像分辨率。
  5. 接下来,指定StartPageEndPage以将一系列页面呈现为图像。
  6. 然后,调用DoConvert()方法将所选页面呈现为图像。
  7. 接下来,保存图像以循环播放。
  8. 然后,使用流对象创建BarCodeReader类的实例。
  9. 之后,调用ReadBarCodes()方法获取BarCodeResult对象。
  10. 最后,显示条码信息。

以下代码示例展示了如何使用 C# 将 PDF 页面转换为图像并读取条形码

// The following code example shows how to convert PDF pages into images with PDF Convertor and read barcodes using C#.
// The path to the document
string file = @"C:\Files\BarCode\sample-PDF-with-Barcodes.pdf";

// Load a PDF document
Aspose.Pdf.Document pdfDoc = new Aspose.Pdf.Document(file);

// Initialize a PdfConvertor
Aspose.Pdf.Facades.PdfConverter pdfConverter = new Aspose.Pdf.Facades.PdfConverter(pdfDoc);

// Set barcode optimization
pdfConverter.RenderingOptions.BarcodeOptimization = true;

// Set page resolution
// 300 dpi is standard resolution
pdfConverter.Resolution = new Aspose.Pdf.Devices.Resolution(300);

// Set all pages to render into images
pdfConverter.StartPage = 1; //starts from page 1
pdfConverter.EndPage = pdfConverter.Document.Pages.Count;

// Render selected pages into the images
pdfConverter.DoConvert();
while (pdfConverter.HasNextImage())
{
// Render current page to memory stream image
MemoryStream ms = new MemoryStream();
pdfConverter.GetNextImage(ms, ImageFormat.Png);
ms.Position = 0;

// Recognize barcodes from the rendered image of the page
BarCodeReader reader = new BarCodeReader(ms);

// Show results
foreach (BarCodeResult result in reader.ReadBarCodes())
{
Console.WriteLine("Codetext found: " + result.CodeText);
Console.WriteLine("Symbology: " + result.CodeType);
Console.WriteLine("-------------------------------");
}
}
4、在 C# 中使用 PngDevice 从 PDF 读取条形码

这是另一种类似于前一种的方法。唯一不同的是,在这个方法中,我们将使用 API 的类将 PDF 文档的页面转换为图像。它允许将 PDF 文档的页面转换为 PNG 图像。

我们可以按照以下步骤将转换后的 PDF 页面中的条形码读取为 PNG 图像:

  1. 首先,使用Document类加载 PDF 文档。
  2. 接下来,创建PngDevice类的实例。
  3. 然后,遍历所有页面并调用Process()方法以渲染到流中。
  4. 接下来,使用流对象创建BarCodeReader类的实例。
  5. 之后,调用ReadBarCodes()方法获取BarCodeResult对象。
  6. 最后,显示条码信息。

以下代码示例展示了如何将 PDF 页面转换为 PNG 图像并使用 C# 读取条形码

// The following code example shows how to convert PDF pages into images with PDF Convertor and read barcodes using C#.
// The path to the document
string file = @"C:\Files\BarCode\sample-PDF-with-Barcodes.pdf";

// Load a PDF document
Aspose.Pdf.Document pdfDoc = new Aspose.Pdf.Document(file);

// Initialize a PdfConvertor
Aspose.Pdf.Facades.PdfConverter pdfConverter = new Aspose.Pdf.Facades.PdfConverter(pdfDoc);

// Set barcode optimization
pdfConverter.RenderingOptions.BarcodeOptimization = true;

// Set page resolution
// 300 dpi is standard resolution
pdfConverter.Resolution = new Aspose.Pdf.Devices.Resolution(300);

// Set all pages to render into images
pdfConverter.StartPage = 1; //starts from page 1
pdfConverter.EndPage = pdfConverter.Document.Pages.Count;

// Render selected pages into the images
pdfConverter.DoConvert();
while (pdfConverter.HasNextImage())
{
// Render current page to memory stream image
MemoryStream ms = new MemoryStream();
pdfConverter.GetNextImage(ms, ImageFormat.Png);
ms.Position = 0;

// Recognize barcodes from the rendered image of the page
BarCodeReader reader = new BarCodeReader(ms);

// Show results
foreach (BarCodeResult result in reader.ReadBarCodes())
{
Console.WriteLine("Codetext found: " + result.CodeText);
Console.WriteLine("Symbology: " + result.CodeType);
Console.WriteLine("-------------------------------");
}
}
5、使用 C# 从 PDF 中提取和读取条形码

我们还可以使用类识别嵌入在 PDF 页面上的条形码图像。它允许从 PDF 中提取图像,然后我们将从提取的图像中读取条形码信息。

我们可以按照以下步骤从提取的图像中读取条形码:

  1. 首先,创建PdfExtractor类的实例。
  2. 接下来,使用BindPdf()方法绑定输入的 PDF 文档。
  3. 然后,设置图像提取的页面范围。
  4. 接下来,调用ExtractImage()方法来提取图像。
  5. 然后,保存图像以循环播放。
  6. 接下来,使用流对象创建BarCodeReader类的实例。
  7. 之后,调用ReadBarCodes()方法获取BarCodeResult对象。
  8. 最后,显示条码信息。

以下代码示例展示了如何使用 C# 从 PDF 文档中提取和读取条形码图像

// The following code example shows how to convert PDF pages into images with PdfExtractor and read barcodes using C#.
// The path to the document
string file = @"C:\Files\BarCode\sample-PDF-with-Barcodes.pdf";

// Bind a PDF document
Aspose.Pdf.Facades.PdfExtractor pdfExtractor = new Aspose.Pdf.Facades.PdfExtractor();
pdfExtractor.BindPdf(file);

// Set page range for image extraction
pdfExtractor.StartPage = 1;
pdfExtractor.EndPage = 3;

// Extract the images
pdfExtractor.ExtractImage();

// Save images to stream in a loop
while (pdfExtractor.HasNextImage())
{
// Save image to stream
MemoryStream imageStream = new MemoryStream();
pdfExtractor.GetNextImage(imageStream);
imageStream.Position = 0;

// Recognize the barcodes from the image stream above
BarCodeReader reader = new BarCodeReader(imageStream);
foreach (BarCodeResult result in reader.ReadBarCodes())
{
Console.WriteLine("Codetext found: " + result.CodeText);
Console.WriteLine("Symbology: " + result.CodeType);
Console.WriteLine("-------------------------------");
}
}

6、使用 C# 从 PDF 中查找和读取条形码图像

我们还可以使用类从 PDF 文档中查找和提取条形码图像。它表示图像放置对象的吸收体对象。它执行图像使用搜索,并通过 ImagePlacements 集合提供对搜索结果的访问。此方法有助于识别具有原始分辨率的条码。它可能无法正确识别矢量格式。

我们可以按照以下步骤从 PDF 文档中查找和读取条形码:

  1. 首先,使用Document类加载 PDF 文档。
  2. 接下来,创建ImagePlacementAbsorber类的实例。
  3. 然后,在循环中为每个页面调用Visit()方法。
  4. 接下来,遍历ImagePlacements集合中找到的所有图像。
  5. 然后,将图像保存到内存流中。
  6. 接下来,使用流对象创建BarCodeReader类的实例。
  7. 之后,调用ReadBarCodes()方法获取BarCodeResult对象。
  8. 最后,显示条码信息。

以下代码示例展示了如何使用 C# 从 PDF 中查找和读取条形码图像

// This code example demonstrates how to read a barcode from a PDF document using ImagePlacementAbsorber.
// The path to the document
string file = @"C:\Files\BarCode\sample-PDF-with-Barcodes.pdf";

// Load a PDF document
Aspose.Pdf.Document pdfDoc = new Aspose.Pdf.Document(file);

// Initialize ImagePlacementAbsorber
Aspose.Pdf.ImagePlacementAbsorber imagePlacementAbsorber = new Aspose.Pdf.ImagePlacementAbsorber();

// Process all PDF pages in the document starting from page 1
for (int i = 1; i <= pdfDoc.Pages.Count; ++i)
{
// Visit the page create an image extractor
imagePlacementAbsorber.Visit(pdfDoc.Pages[i]);

// Extract all images from the PDF page
foreach (Aspose.Pdf.ImagePlacement imagePlacement in imagePlacementAbsorber.ImagePlacements)
{
// Convert an image from the PDF page to the stream
MemoryStream ms = new MemoryStream();
imagePlacement.Save(ms, ImageFormat.Png);
ms.Position = 0;

// Recognize barcode from extracted image of the page
BarCodeReader reader = new BarCodeReader(ms);

// Show results
foreach (BarCodeResult result in reader.ReadBarCodes())
{
Console.WriteLine("Codetext found: " + result.CodeText);
Console.WriteLine("Symbology: " + result.CodeType);
Console.WriteLine("-------------------------------");
}
}
}

以上便是如何在 C# 中从 PDF 读取条形码 ,要是您还有其他关于产品方面的问题,欢迎咨询我们,或者加入我们官方技术交流群。


欢迎下载|体验更多Aspose产品

获取更多信息请咨询 或 加入Aspose技术交流群(761297826

标签:

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@pclwef.cn


为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
扫码咨询


添加微信 立即咨询

电话咨询

客服热线
023-68661681

TOP