PaddleOCRSharp

470 阅读2分钟

本文已参与「新人创作礼」活动,一起开启掘金创作之路。

PaddleOCRSharp

        本项目是一个基于百度飞桨的PaddleOCR的C++代码修改并封装的.NET的类库。包含文本识别、文本检测、基于文本检测结果的统计分析的表格识别功能,同时针对小图识别不准的情况下,做了优化,提高识别准确率。项目封装极其简化,实际调用仅一行代码,极大的方便了中下游开发者的使用和降低了PaddleOCR的使用入门级别,同时提供不同的.NET框架使用,方便各个行业应用开发与部署。\

其中PaddleOCR.dll文件是基于开源项目PaddleOCR的C++代码修改而成的C++动态库,基于opencv的x64编译而成的。

模型库支持轻量版(本项目)、服务器版模型库(更准确),可以自行更改模型库适用实际需求。

关于源码编译,建议采用vs2019及以上版本编译,如果遇到无法编译,请切换成release后再切换回debug即可。

        本项目包含文本识别、文本检测、基于文本检测结果的统计分析的表格识别功能,同时针对小图识别不准的情况下,做了优化,提高识别准确率。项目封装极其简化,实际调用仅一行代码,极大的方便了中下游开发者的使用和降低了PaddleOCR的使用入门级别,同时提供不同的.NET框架使用,支持框架如下:

net40;net461;netstandard2.0;netcoreapp3.1;net5.0;

方便各个行业应用开发与部署。

.NET示例代码

OpenFileDialog ofd = new OpenFileDialog();            
ofd.Filter = "*.*|*.bmp;*.jpg;*.jpeg;*.tiff;*.tiff;*.png";            
if (ofd.ShowDialog() != DialogResult.OK) return;           
var imagebyte = File.ReadAllBytes(ofd.FileName);           
Bitmap bitmap = new Bitmap(new MemoryStream(imagebyte));           
OCRResult ocrResult = PaddleOCRSharp.PaddleOCRHelper.DetectText(bitmap,null);            
if (ocrResult != null)           
{                
    MessageBox.Show(ocrResult.Text,"识别结果");            
}
```

\`