Tesseract centos环境安装,基于springboot图片提取文字

下载tesseract-orc

https://github.com/tesseract-ocr/tesseract/tags

下载leptonica

wget http://www.leptonica.org/source/leptonica-1.78.0.tar.gz

解压leptonica
tar -xvf leptonica-1.78.0.tar.gz
配置编译安装leptonica
进文件夹

./configure
make
make install

安装automake和libtool

yum install automake
yum install libtool

配置leptonica环境变量

vi /etc/profile

export LD_LIBRARY_PATH=/usr/local/lib
export LIBLEPT_HEADERSDIR=/usr/local/include
export PKG_CONFIG_PATH=/usr/local/lib/pkgconfig

source /etc/profile

安装tesseract-ocr
进文件夹

./autogen.sh
./configure
make
make install

编译的时候遇到问题
Your-compiler-does-not-have-the-necessary-C17-support
执行

yum install -y centos-release-scl
yum install devtoolset-8-gcc*
scl enable devtoolset-8 bash

重新编译

测试是否安装成功,执行

ldconfig
tesseract --version

将下载的语言包复制到/usr/local/share/tessdata
最新包

<dependency>
   <groupId>net.sourceforge.tess4j</groupId>
   <artifactId>tess4j</artifactId>
   <version>5.6.0</version>
</dependency>
springboot 解决 jna 找不到对应的文件

<dependency>
   <groupId>net.java.dev.jna</groupId>
   <artifactId>jna</artifactId>
   <version>5.13.0</version>
</dependency>

demo

@PostMapping("/upload")
public String testFile(MultipartFile file){
    try {
        Tesseract instance = new Tesseract();
        instance.setLanguage("eng+chi_sim");
        instance.setHocr(false);
        instance.setPageSegMode(ITessAPI.TessPageSegMode.PSM_AUTO_OSD);
        instance.setOcrEngineMode(TessAPI.TessOcrEngineMode.OEM_LSTM_ONLY);
        PDDocument document = PDDocument.load(file.getInputStream());
        PDFRenderer pdfRenderer = new PDFRenderer(document);
        BufferedImage bim = pdfRenderer.renderImageWithDPI(0, 200, ImageType.RGB);
        String result = instance.doOCR(bim);
        return result;
    } catch (IOException | TesseractException e) {
        e.printStackTrace();
    }
    return "";
}
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值