AI工具【OCR 01】Java可使用的OCR工具Tess4J使用举例(身份证信息识别核心代码及信息提取方法分享)

本文涉及的产品
检索分析服务 Elasticsearch 版,2核4GB开发者规格 1个月
实时计算 Flink 版,5000CU*H 3个月
实时数仓Hologres,5000CU*H 100GB 3个月
简介: 【2月更文挑战第1天】Lept4J和Tess4J都是基于Tesseract OCR引擎的Java接口,可以用来识别图像中的文本,本次介绍Tess4J

1.简介

1.1 简单介绍

Lept4J和Tess4J都是基于Tesseract OCR引擎的Java接口,可以用来识别图像中的文本:

  • 前者是Leptonica图像处理库的Java封装,提供了图像的加载、处理、分析等功能。
  • 后者是Tesseract OCR引擎的Java封装,提供了图像的OCR识别、PDF文档的生成等功能。

Lept4J和Tess4J的区别在于,Lept4J主要负责图像的预处理,而Tess4J主要负责图像的后处理,特点分别是:

  • Lept4J支持多种图像格式,可以进行图像的缩放、旋转、裁剪、二值化、降噪等操作,提高图像的质量和识别率。
  • Tess4J支持多种语言的识别,可以生成文本、HTML、PDF等格式的输出,提供了多种识别模式和参数设置,满足不同的需求。

根据具体场景和需求,可以选择使用Lept4J或Tess4J,或者结合使用两者,以达到最佳的效果。

1.2 官方说明

官网:https://tess4j.sourceforge.net/
描述:A Java JNA wrapper for Tesseract OCR API.Tess4J is released and distributed under the Apache License, v2.0 and is also available from Maven Central Repository.
特性:The library provides optical character recognition (OCR) support for:

  • TIFF, JPEG, GIF, PNG, and BMP image formats
  • Multi-page TIFF images
  • PDF document format

    2.使用举例

    2.1 依赖及语言数据包

    <!-- https://mvnrepository.com/artifact/net.sourceforge.tess4j/tess4j -->
    <dependency>
          <groupId>net.sourceforge.tess4j</groupId>
          <artifactId>tess4j</artifactId>
          <version>5.9.0</version>
    </dependency>
    

    语言数据包下载地址:https://github.com/tesseract-ocr/tessdata
    LanguageData.jpg

    2.2 核心代码

      /**
       * 识别图片字符信息
       *
       * @param imagePath 图片路径
       */
      private static String recognitionString(String imagePath) {
         
          File imageFile = new File(imagePath);
          ITesseract instance = new Tesseract();
          // 1.语言数据包路径
          instance.setDatapath("tessdata");
          // 2.加载语言文件名称
          instance.setLanguage("chi_sim");
          String result = "";
          try {
         
              result = instance.doOCR(imageFile);
          } catch (TesseractException e) {
         
              e.printStackTrace();
          }
          return result;
      }
    

    2.3 识别身份证信息

    2.3.1 核心代码

      /**
       * 识别身份证信息
       *
       * @param imagePath 图片路径
       */
      private static Map<String, Object> recognitionIdentityCardInfo(String imagePath) {
         
          Map<String, Object> res = new HashMap<>(2);
          // 识别图片
          File imageFile = new File(imagePath);
          BufferedImage bufferedImage = null;
          try {
         
              bufferedImage = ImageIO.read(imageFile);
          } catch (IOException e) {
         
              e.printStackTrace();
          }
          ITesseract instance = new Tesseract();
          instance.setDatapath("tessdata");
          instance.setLanguage("chi_sim");
          List<Word> words = instance.getWords(bufferedImage, 1);
          // 获取姓名
          int nameLineIndex = 0;
          if (words.size() > nameLineIndex) {
         
              res.put("name", getStringByIndex(words.get(0).getText(), 2));
          }
          // 获取性别和民族
          int genderAndNationLineIndex = 1;
          if (words.size() > genderAndNationLineIndex) {
         
              res.put("gender", getStringByIndex(words.get(1).getText(), 2, 1));
              res.put("nation", removeNonChinese(getStringByIndex(words.get(1).getText(), 5, -1)));
          }
          // 获取出生日期
          int birthLineIndex = 2;
          if (words.size() > birthLineIndex) {
         
              res.put("birth", extractBirthDate(getStringByIndex(words.get(2).getText(), 2)));
          }
          // 获取住址
          int addressLineIndex = 3;
          if (words.size() > addressLineIndex) {
         
              res.put("address", getStringByIndex(words.get(3).getText(), 2).replace("/", ""));
          }
          // 获取身份证号码
          int noLineIndex = 4;
          if (words.size() > noLineIndex) {
         
              res.put("no", getStringByIndex(words.get(4).getText(), 7));
          }
          return res;
      }
    

    2.3.2 截取指定字符

      /**
       * 截取指定字符
       *
       * @param inputString 字符串
       * @param indexStart  开始Index
       * @return 截取的字符串
       */
      private static String getStringByIndex(String inputString, int indexStart) {
         
          return getStringByIndex(inputString, indexStart, -1);
      }
    
      /**
       * 截取指定字符
       *
       * @param inputString 字符串
       * @param indexStart  开始Index
       * @param size        截取的字符个数
       * @return 截取的字符串
       */
      private static String getStringByIndex(String inputString, int indexStart, int size) {
         
          // 去除字符串两端的空白字符
          String trimmedString = inputString.trim();
          // 将字符串以空白字符分割
          StringBuilder res = new StringBuilder();
          String[] words = trimmedString.split("\\s+");
          int length = words.length;
          int contentSize = indexStart + size;
          if (length > indexStart) {
         
              int index = length;
              if (size > 0 && length > contentSize) {
         
                  index = contentSize;
              }
              for (int i = indexStart; i < index; i++) {
         
                  res.append(words[i]);
              }
          }
          return res.toString();
      }
    

    2.3.3 去掉字符串里的非中文字符

      /**
       * 去掉字符串里的非中文字符
       *
       * @param inputString 字符串
       * @return 中文字符串
       */
      private static String removeNonChinese(String inputString) {
         
          // 匹配非汉字字符的正则表达式
          String regex = "[^\u4E00-\u9FA5]";
          Pattern pattern = Pattern.compile(regex);
          Matcher matcher = pattern.matcher(inputString);
          // 替换非汉字字符为空格
          return matcher.replaceAll("");
      }
    

    2.3.4 提取出生日期(待优化)

      /**
       * 提取出生日期
       *
       * @param inputString 字符串
       * @return 出生日期
       */
      private static String extractBirthDate(String inputString) {
         
          // 匹配日期格式的正则表达式
          String regex = "(\\d{4}年\\d{2}月\\d{2}日)";
          Pattern pattern = Pattern.compile(regex);
          Matcher matcher = pattern.matcher(inputString);
          // 提取匹配到的日期
          if (matcher.find()) {
         
              return matcher.group(1);
          } else {
         
              return "未找到日期";
          }
      }
    

    2.3.5 实测

    图片:
    ID.jpg
    结果:

    {
         name=代用名, gender=男, nation=汉, birth=20130506, address=湖南省长沙市开福区送道街仪幸福小区居民组, no=30512198908131367}
    
  • 姓名 正确

  • 性别 正确
  • 民族 正确
  • 出生 正确
  • 住址 错了一个字(巡)多了一个字(仪)
  • 公民身份证号码 缺少首位(4)

    3.总结

  • Java能用挺友好

  • 缺点是识别率有点儿低
目录
相关文章
|
11天前
|
Java
在 Java 中捕获和处理自定义异常的代码示例
本文提供了一个 Java 代码示例,展示了如何捕获和处理自定义异常。通过创建自定义异常类并使用 try-catch 语句,可以更灵活地处理程序中的错误情况。
|
21天前
|
jenkins Java 测试技术
如何使用 Jenkins 自动发布 Java 代码,通过一个电商公司后端服务的实际案例详细说明
本文介绍了如何使用 Jenkins 自动发布 Java 代码,通过一个电商公司后端服务的实际案例,详细说明了从 Jenkins 安装配置到自动构建、测试和部署的全流程。文中还提供了一个 Jenkinsfile 示例,并分享了实践经验,强调了版本控制、自动化测试等关键点的重要性。
57 3
|
22天前
|
分布式计算 Java MaxCompute
ODPS MR节点跑graph连通分量计算代码报错java heap space如何解决
任务启动命令:jar -resources odps-graph-connect-family-2.0-SNAPSHOT.jar -classpath ./odps-graph-connect-family-2.0-SNAPSHOT.jar ConnectFamily 若是设置参数该如何设置
|
21天前
|
Java
Java代码解释++i和i++的五个主要区别
本文介绍了前缀递增(++i)和后缀递增(i++)的区别。两者在独立语句中无差异,但在赋值表达式中,i++ 返回原值,++i 返回新值;在复杂表达式中计算顺序不同;在循环中虽结果相同但使用方式有别。最后通过 `Counter` 类模拟了两者的内部实现原理。
Java代码解释++i和i++的五个主要区别
|
机器学习/深度学习 人工智能 开发者
资源 | AI领域最优论文+代码查找神器:966个ML任务、8500+论文任君挑选!
查找论文及对应源码的神器 Papers With Code 刚刚推出了最新版本,可以用图形界面查找你想要的 SOTA 实现,从应用领域到具体任务再到实现代码一步到位。
|
3天前
|
机器学习/深度学习 人工智能 算法
AI技术在医疗诊断中的应用及前景展望
本文旨在探讨人工智能(AI)技术在医疗诊断领域的应用现状、挑战与未来发展趋势。通过分析AI技术如何助力提高诊断准确率、缩短诊断时间以及降低医疗成本,揭示了其在现代医疗体系中的重要价值。同时,文章也指出了当前AI医疗面临的数据隐私、算法透明度等挑战,并对未来的发展方向进行了展望。
|
11天前
|
机器学习/深度学习 人工智能 自然语言处理
当前AI大模型在软件开发中的创新应用与挑战
2024年,AI大模型在软件开发领域的应用正重塑传统流程,从自动化编码、智能协作到代码审查和测试,显著提升了开发效率和代码质量。然而,技术挑战、伦理安全及模型可解释性等问题仍需解决。未来,AI将继续推动软件开发向更高效、智能化方向发展。
|
15天前
|
机器学习/深度学习 人工智能 自然语言处理
AI在医疗领域的应用及其挑战
【10月更文挑战第34天】本文将探讨人工智能(AI)在医疗领域的应用及其面临的挑战。我们将从AI技术的基本概念入手,然后详细介绍其在医疗领域的各种应用,如疾病诊断、药物研发、患者护理等。最后,我们将讨论AI在医疗领域面临的主要挑战,包括数据隐私、算法偏见、法规合规等问题。
40 1
|
7天前
|
机器学习/深度学习 人工智能 算法
AI在医疗诊断中的应用
【10月更文挑战第42天】本文将探讨人工智能(AI)在医疗诊断中的应用,包括其优势、挑战和未来发展方向。我们将通过实例来说明AI如何改变医疗行业,提高诊断的准确性和效率。
|
8天前
|
存储 人工智能 搜索推荐
Memoripy:支持 AI 应用上下文感知的记忆管理 Python 库
Memoripy 是一个 Python 库,用于管理 AI 应用中的上下文感知记忆,支持短期和长期存储,兼容 OpenAI 和 Ollama API。
44 6
Memoripy:支持 AI 应用上下文感知的记忆管理 Python 库
下一篇
无影云桌面