Which library to use to extract text from images?

荒凉一梦 提交于 2019-12-09 12:00:03

问题


I am writing a program that when given an image of a low level math problem (e.g. 98*13) should be able to output the answer. The numbers would be black, and the background white. Not a captcha, just an image of a math problem.

The math problems would only have two numbers and one operator, and that operator would only be +, -, *, or /.

Obviously, I know how to do the calculating ;) I'm just not sure how to go about getting the text from the image.

A free library would be ideal... although If I have to write the code myself I could probably manage.


回答1:


Try this post regarding using the C++ Google Tessaract OCR lib in C#

OCR with the Tesseract interface




回答2:


For extract words from image, I use the most accurate open source OCR engine: Tesseract. Available here or directly in your packages NuGet.

And this is my function in C#, which extract words from image passed in sourceFilePath. Set EngineMode to TesseractAndCube; it detect more word than the other options.

var path = "YourSolutionDirectoryPath";
using (var engine = new TesseractEngine(path + Path.DirectorySeparatorChar + "tessdata", "fra", EngineMode.TesseractAndCube))
{
    using (var img = Pix.LoadFromFile(sourceFilePath))
    {
        using (var page = engine.Process(img))
        {
            var text = page.GetText();
            // text variable contains a string with all words found
        }
    }
}

I hope that helps.




回答3:


You need OCR. There is the free Tesseract library from Google, but it's C code. You could use in a C++/CLI project and access via .NET.

This article gives some information on recognizing numbers (for Sudoku, but your problem is similar)

http://sudokugrab.blogspot.com/2009/07/how-does-it-all-work.html




回答4:


you can use Microsoft Office Document Imaging (Interop.MODI.dll) in visaul studio and extract text of pictures

Document modiDocument = new Document();
modiDocument.Create(filePath);
modiDocument.OCR(MiLANGUAGES.miLANG_ENGLISH);
MODI.Image modiImage = (modiDocument.Images[0] as MODI.Image);
string extractedText = modiImage.Layout.Text;
modiDocument.Close();
return extractedText;


来源:https://stackoverflow.com/questions/5146597/which-library-to-use-to-extract-text-from-images

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!