导出OCR结果到JSON - c#.net核心

本教程展示了如何在使用LEADTOOLS SDK的c# . net Core应用程序中对图像进行OCR并将OCR结果导出为JSON文件。

概述
总结 本教程介绍如何在c# . net Core Console应用程序中将OCR结果保存为JSON文件。
完成时间 30分钟
Visual Studio项目 下载教程项目(1kb)
平台 核心控制台应用程序
IDE Visual Studio 2019, 2022
开发许可 下载LEADTOOLS
用另一种语言试试

所需的知识

来熟悉创建项目的基本步骤添加引用和设置License教程,在工作之前导出OCR结果到JSON - c#.net核心教程。

创建项目并添加LEADTOOLS引用

中创建的项目的副本开始添加引用和设置License教程。如果您没有该项目,请按照该教程中的步骤创建它。

所需的参考资料取决于项目的目的。引用可以通过NuGet包添加。

本教程需要以下NuGet包:

有关应用程序需要哪些DLL文件的完整列表,请参阅与您的应用程序包含的文件

设置License文件

许可证解锁项目所需的特性。它必须在调用任何工具包函数之前设置。有关详细信息,包括针对不同平台的教程,请参阅设置运行时License

有两种类型的运行时许可证:

请注意

中详细介绍了添加LEADTOOLS NuGet引用和设置许可证添加引用和设置License教程。

初始化OcrEngine

随着项目的创建、引用的添加和许可证的设置,编码就可以开始了。

解决方案资源管理器,打开Program.cs.将以下语句添加到使用块的顶部Program.cs

c#
使用系统;使用先;使用System.Collections.Generic;使用Newtonsoft.Json;使用Leadtools;使用Leadtools.Ocr;使用Leadtools.Document;

添加一个名为InitOcrEngine ()返回IOcrEngine并在里面调用它Main ()方法后SetLicense ()方法调用,如下所示。

c#
静态无效主要(字符串[]参数)如果(! SetLicense ())控制台。WriteLine (“设置许可证错误”);其他的控制台。WriteLine ("License文件设置成功");字符串文件=@“C: \ LEADTOOLS22 \资源\ \ leadtools.pdf图像”IOcrEngine ocrEngine = InitOcrEngine();OCRandSaveResults (ocrEngine、文件);

将下面的代码添加到InitOcrEngine ()方法初始化IOcrEngine

c#
静态IOcrEngine InitOcrEngine ()//初始化OCR引擎IOcrEngine ocrEngine = OcrEngineManager.CreateEngine(ocrengintype . lead);ocrEngine。启动(@“C: \ LEADTOOLS22 \ Bin \常见\ OcrLEADRuntime”);返回ocrEngine;

添加文本识别和导出到JSON代码

在Program类中创建一个名为OCRandSaveResults(IOcrEngine ocrEngine,字符串文件)把它叫做Main ()方法后IOcrEngine ocrEngine = InitOcrEngine();行代码。将下面的代码添加到OCRandSaveResults ()方法对PDF文档进行OCR,并将识别结果导出为JSON文件。

c#
静态无效OCRandSaveResults (IOcrEngine ocrEngine,字符串文件)使用vardocument = DocumentFactory。LoadFromFile(文件,LoadDocumentOptions {FirstPageNumber = 1, LastPageNumber = -1}))document.Text.OcrEngine = ocrEngine;List DocumentPageText =列表< DocumentPageText > ();foreachvar页面document.Pages)//解析文本并构建DocumentPageText对象varpageText = page.GetText();pageText.BuildText ();pageText.BuildWords ();documentPageTexts.Add (pageText);//将识别的单词保存为JSON格式varjson = JsonConvert。SerializeObject (documentPageTexts Formatting.Indented);varjsonPath =路径。ChangeExtension(文件,. json”);文件。WriteAllText (jsonPath、json);

处理流

或者,您也可以使用内存流来处理文档。方法中调用此方法,将以下代码添加到程序中Main (string [] args)方法:

c#
静态无效OCRStreamandSaveResults (IOcrEngine ocrEngine)//加载指定的文档var文件名= Path.Combine(LEAD_VARS.ImagesDir,“Leadtools.pdf”);使用varstream = File.OpenRead(fileName))var选择=LoadDocumentOptions ();使用vardocument = DocumentFactory。LoadFromStream(流、期权))document.Text.OcrEngine = ocrEngine;控制台。WriteLine (“医生”加载);List DocumentPageText =列表< DocumentPageText > ();foreachvar页面document.Pages)//解析文本并构建DocumentPageText对象varpageText = page.GetText();pageText.BuildText ();pageText.BuildWords ();documentPageTexts.Add (pageText);//将识别的单词保存为JSON格式varjson = JsonConvert。SerializeObject (documentPageTexts Formatting.Indented);varjsonPath =路径。ChangeExtension(文件名,. json”);文件。WriteAllText (jsonPath、json);
一定要添加LEAD_VARS类,以便ImagesDir可访问。

c#
静态LEAD_VARS公共常量字符串ImagesDir =@“C: \ LEADTOOLS22 \ Resources \图片”

运行项目

通过按运行项目F5,或选择Debug ->开始调试

如果正确地遵循了这些步骤,应用程序将对文档进行OCR并创建包含识别结果的JSON。在本教程中,我们使用了位于这里的PDF文件:< INSTALL_DIR > \ LEADTOOLS22 \ \ \ leadtools.pdf图像资源

下载得到的JSON在这里

总结

本教程展示了如何在文档上运行OCR并将结果导出为JSON。此外,还介绍了如何使用IOcrEngine接口,以及LEADDocumentDocumentPage而且DocumentPageText类。

另请参阅

net
iOS
188金宝搏的网址客服|支持|联系我们|知识产权公告
©1991 - 2022领先技术公司版权所有