VS2012成功编译后的tesseract链接:http://download.csdn.net/download/qq_15947787/10042499

———————————————————————————————————————————————

问题1:

再编译tesseract-vs2012-master时遇到了这样的warning,并带来一系列莫名其妙的error。

warning C4819 该文件包含不能在当前代码页(936)中表示的字符。请将该文件保存为 Unicode 格式以防止数据丢失


解决方法:

首先打开有该warning的文件,点击【文件】选【高级保存选项】,显示如下,或是其他别的编码格式,

现在开始改变编码格式为【简体中文(GB2312代码页936】或【Unicode】,总之是适合自己的编码格式

点击【确定】后保存,重新编译,warning消失。

———————————————————————————————————————————————


问题2:Please make sure the TESSDATA_PREFIX environment variable is set to the parent directory of your "tessdata" directory.Failed loading language 'eng' .Tesseract couldn't load any languages!


测试代码

#include <opencv2/highgui/highgui.hpp>  
#include <opencv2/imgproc/imgproc.hpp>  
#include <tesseract/baseapi.h>  
#include <iostream>


int main(int argc, char** argv)  
{  
	// Load image  
	cv::Mat im = cv::imread("t.bmp");  
	if (im.empty())  
	{  
		std::cout << "Cannot open source image!" << std::endl;  
		return -1;  
	}  

	cv::Mat gray;  
	cv::cvtColor(im, gray, CV_BGR2GRAY);  
	// ...other image pre-processing here...  

	// Pass it to Tesseract API  
	tesseract::TessBaseAPI tess;  
	tess.Init(NULL, "eng", tesseract::OEM_DEFAULT);  
	tess.SetPageSegMode(tesseract::PSM_SINGLE_BLOCK);  
	tess.SetImage((uchar*)gray.data, gray.cols, gray.rows, 1, gray.cols);  

	// Get the text  
	char* out = tess.GetUTF8Text();  
	std::cout << out << std::endl;  

	return 0;  
} 

解决方法:

从下面源码中可以分析:如果定义了TESSDATA_PREFIX这个环境变量,datadir则使用环境变量的路径,如果未定义这个环境变量,则通过argv0传入的参数,也就是tess.Init的第一个参数。


删除系统环境变量TESSDATA_PREFIX,程序默认从工程目录/可执行文件目录寻找tessdata,只要将tessdata下的文件拷贝过来即可。


GitHub 加速计划 / te / tesseract
60.1 K
9.29 K
下载
tesseract-ocr/tesseract: 是一个开源的光学字符识别(OCR)引擎,适用于从图像中提取和识别文本。特点是可以识别多种语言,具有较高的识别准确率,并且支持命令行和API调用。
最近提交(Master分支:23 天前 )
bc490ea7 Don't check for a directory, because a symbolic link is also allowed. Signed-off-by: Stefan Weil <sw@weilnetz.de> 2 个月前
2991d36a - 2 个月前
Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐