Java 版本:建议JDK1.8

使用的软件是tesseractocr3.02,3以后的版本才支持中文, 这个软件需要安装在本地电脑中,安装的过程中全部都按照默认进行安装(以便于Java直接调用)

代码及所使用的软件插件及jar包地址如下:

https://download.csdn.net/download/weixin_40461281/10609983

该软件默认的识别的是英文,如果相要能识别中文,需要将中文的训练文本chi_sim.traineddata存放到(安装路径下\Tesseract-OCR\tessdata)中

Java中识别的话很简单 , 下面是封装的工具类

import net.sourceforge.tess4j.Tesseract;

import javax.imageio.ImageIO;

import java.awt.image.BufferedImage;

import java.io.File;

import java.io.IOException;

public class OCR {

/**

*

* @param srImage 图片路径

* @param ZH_CN 是否使用中文训练库,true-是

* @return 识别结果

*/

public static String FindOCR(String srImage, boolean ZH_CN) {

try {

System.out.println("start");

double start=System.currentTimeMillis();

File imageFile = new File(srImage);

if (!imageFile.exists()) {

return "图片不存在";

}

BufferedImage textImage = ImageIO.read(imageFile);

Tesseract instance=Tesseract.getInstance();

instance.setDatapath("C:\\Program Files (x86)\\Tesseract-OCR\\tessdata");//设置训练库

if (ZH_CN)

instance.setLanguage("chi_sim");//中文识别

String result = null;

result = instance.doOCR(textImage);

double end=System.currentTimeMillis();

System.out.println("耗时"+(end-start)/1000+" s");

return result;

} catch (Exception e) {

e.printStackTrace();

return "发生未知错误";

}

}

public static void main(String[] args) throws Exception {

String result=FindOCR("D:\\test2.png",true);

System.out.println(result);

}

}

Logo

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐