zoukankan      html  css  js  c++  java
  • Tesseract OCR简单实用介绍

    做字符识别,不能不了解google的Tesseract-OCR,但是如何在自己的工程中使用其API倒是语焉不详,官网上倒是很详尽地也很啰嗦地介绍如何重新编译生成适合自己平台的lib和dll,经过近些天的不断搜索和尝试,可算是找了些门路。尤其感谢以下作者的分享带给我的帮助和启发:

    <span>cxf7394373</span>的 字符识别Google开源Tesseract-ocr的DLL调用方法

    <span>夏梦c</span>Tesseract3.02简单环境搭建

    <span>tsinson</span>的 tesseract下的简单应用

           下面开始介绍我的使用经验:

    一,下载lib和dll

    可以从这里http://code.google.com/p/tesseract-ocr/downloads/list  下载

    tesseract-ocr-setup-3.02.02.exe Windows installer of tesseract-ocr 3.02.02 (including English language data)   Featured

    然后进行安装,如此可以方便地省去好多配置细节:如修改环境变量【如果不采用环境变量方式,则需要对于每个工程目录建立tessdata文件夹,并且里面放置所需要的chi_sim.traineddata等语言包】,也不再需要下载tesseract-3.02.02-win32-lib-include-dirs.zip, 更方便以后训练出自己的traineddata 文件

    需要注意的是,安装目录下lib里面 libtesseract302d.dll 是针对VS2008的,需要用一个vs2010编译出的替换下来才可以在VS2010下正常使用。

    另外还需要将 liblept168.dll 和 liblept168d.dll两个文件一并下载放到lib里面。 【这三个文件均可以从tsinson提供的样例工程里面找到】

    二,修改环境变量Path

          在环境变量Path中增加指向安装目录下lib的路径,比如C:Program FilesTesseract-OCRlib  ,以便exe运行时能找到所需要的dll

    三,工程中属性中增加路径

          在自己的工程属性中VC++目录下增加包含目录和库目录,以便VS2010查找文件。例如

    包含目录  下新增:C:Program FilesTesseract-OCRinclude esseract

    库目录     下新增: C:Program FilesTesseract-OCRlib 

    四,增加语言训练包

          直接将语言训练包放置在安装目录tessdata文件夹下就好,比如将tesseract-ocr-3.02.chi_sim.tar.gz中的chi_sim.traineddata 文件直接抽取出来放在  C:Program FilesTesseract-OCR essdata 下面,就可以支持中文简体字符的识别啦。当然,自己训练出来的traineddata 文件也是要放在这里的才生效。

    五,API简单使用方法

          这里可以参照<span>cxf7394373</span>的 字符识别Google开源Tesseract-ocr的DLL调用方法

    使用其API的一种模式大致是这样:先包含头文件,连接库;然后再定义一个api类,配置好参数之后提取识别结果

    [cpp] view plaincopy
     
    1.   
    2. #include "strngs.h"   
    3. #include "baseapi.h"   
    4. #pragma  comment(lib,"libtesseract302d.lib")   
    5.   
    6. ////////////////   
    7.     tesseract::TessBaseAPI  api;    
    8.     api.Init(NULL, "eng", tesseract::OEM_DEFAULT);  //初始化,设置语言包,中文简体:chi_sim;英文:eng;也可以自己训练语言包   
    9.     //api.SetVariable( "tessedit_char_whitelist", "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz" );    
    10.      
    11.     STRING text_out;    
    12.     if (!api.ProcessPages("kaze.tif", NULL, 0, &text_out))    
    13.     {    
    14.         //AfxMessageBox("tesseract 处理出现异常");   
    15.         return 0;    
    16.     }     
    17.     cout<<text_out.string();  
    18.     cout<<UTF8ToGBK(text_out.string()).c_str();  
    [cpp] view plaincopy在CODE上查看代码片派生到我的代码片
     
    1. #include "strngs.h"  
    2. #include "baseapi.h"  
    3. #pragma  comment(lib,"libtesseract302d.lib")  
    4.   
    5. ////////////////  
    6.     tesseract::TessBaseAPI  api;    
    7.     api.Init(NULL, "eng", tesseract::OEM_DEFAULT);  //初始化,设置语言包,中文简体:chi_sim;英文:eng;也可以自己训练语言包  
    8.     //api.SetVariable( "tessedit_char_whitelist", "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz" );    
    9.      
    10.     STRING text_out;    
    11.     if (!api.ProcessPages("kaze.tif", NULL, 0, &text_out))    
    12.     {    
    13.         //AfxMessageBox("tesseract 处理出现异常");  
    14.         return 0;    
    15.     }     
    16.     cout<<text_out.string();  
    17.     cout<<UTF8ToGBK(text_out.string()).c_str();  
  • 相关阅读:
    图形设计 X11
    软件安装 RPM SRPM YUM
    如何将excel表格中的纯数字删掉 空白行,然后删除
    考试机
    程序编译与运行
    基础设定与备份策略
    开机流程 模块管理 Loader
    让所有Excel数据格全部乘 某个数
    转:JDK1.8-Stream()使用详解
    转:IK分词原理
  • 原文地址:https://www.cnblogs.com/gisblogs/p/4210484.html
Copyright © 2011-2022 走看看