java图片片识别中文_Java中使用tess4J进行图片文字识别(支持中文)

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);

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Tess4j是一个基于Tesseract OCR引擎的Java库,可以用于识别图像的文字。要获取图像每个文字的坐标,可以使用Tess4j提供的`getWords()`方法。以下是获取图像中文字坐标的代码示例: ```java import java.awt.Rectangle; import java.io.File; import java.util.List; import net.sourceforge.tess4j.ITesseract; import net.sourceforge.tess4j.ITessAPI.TessPageIteratorLevel; import net.sourceforge.tess4j.Tesseract; import net.sourceforge.tess4j.Word; import net.sourceforge.tess4j.util.ImageHelper; public class Tess4jExample { public static void main(String[] args) { File imageFile = new File("example.png"); ITesseract tess = new Tesseract(); tess.setDatapath("tessdata"); try { String text = tess.doOCR(imageFile); System.out.println(text); List<Word> words = tess.getWords(ImageHelper.convertImageToPix(ImageIO.read(imageFile)), TessPageIteratorLevel.RIL_WORD); for (Word word : words) { Rectangle rect = word.getBoundingBox(); System.out.println(word.getText() + " @ (" + rect.x + "," + rect.y + ")"); } } catch (Exception e) { e.printStackTrace(); } } } ``` 在此示例,我们首先使用`doOCR()`方法从图像提取文本。然后,我们使用`getWords()`方法获取每个文字的`Word`对象,并使用`getBoundingBox()`方法获取每个`Word`对象的边界框。最后,我们打印每个文字及其坐标。注意,`getWords()`方法需要一个`Pix`对象,因此我们使用`ImageHelper.convertImageToPix()`方法将`BufferedImage`转换为`Pix`对象。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值