zoukankan      html  css  js  c++  java
  • java实现图片文字识别的两种方法

    一、使用tesseract-ocr

      1.    https://github.com/tesseract-ocr/tesseract/wiki上下载安装包安装和简体中文训练文件

        window64位安装包:tesseract-ocr-w64-setup-v4.1.0.20190314.exe

        简体中文训练文件:chi_sim.traineddata 约40M

      2. 将训练文件chi_sim.traineddata放入安装目录下的tessdata目录中

      3.    配置环境变量,在path变量中加入tesseract安装目录,例如C:\Program Files\Tesseract-OCR

      4. 添加系统环境变量TESSDATA_PREFIX,值为训练文件的目录,例如C:\Program Files\Tesseract-OCR\tessdata

      5. 使用java调用命令行执行转换,命令格式例如:F:\pic>   tesseract 6.png 66 -l chi_sim 即:在F:\pic目录下使用tesseract命令利用chi_sim训练文件把6.png文件转换成66.txt文件

    二、使用tess4j

      1.    使用maven下载所需jar包:

        

    <dependency>
    <groupId>net.java.dev.jna</groupId>
    <artifactId>jna</artifactId>
    <version>4.1.0</version>
    </dependency>
    
    <dependency>
    <groupId>net.sourceforge.tess4j</groupId>
    <artifactId>tess4j</artifactId>
    <version>3.4.0</version>
    <exclusions>
    <exclusion>
    <groupId>com.sun.jna</groupId>
    <artifactId>jna</artifactId>
    </exclusion>
    </exclusions>
    </dependency>

      2.下载简体中文训练文件:chi_sim.traineddata

      3.使用如下代码调用

      

            //加载待读取图片
            File imageFile = new File("F://pic.png");
            //创建tess对象
            ITesseract instance = new Tesseract();
            //设置训练文件目录
            instance.setDatapath("F://tessdata");
            //设置训练语言
            instance.setLanguage("chi_sim");
            //执行转换
            String result = instance.doOCR(imageFile);        

     

  • 相关阅读:
    向量积&&凸包算法
    K短路模板POJ 2449 Remmarguts' Date
    [USACO]奶牛抗议(DP+树状数组+离散化)
    [Uva1642]魔法Gcd(数论)
    [NOIP2012]疫情控制(二分答案+倍增+贪心)
    关于欧几里德算法(gcd)的证明
    旅行(LCA)
    [NOIP2015]运输计划(树上差分+LCA+二分)
    [USACO]奶牛博览会(DP)
    24.基于groovy脚本进行partial update
  • 原文地址:https://www.cnblogs.com/uip001/p/10795621.html
Copyright © 2011-2022 走看看