详细介绍Tess4J的使用:从PDF到图像的OCR技术实现
在当今的数字化时代,OCR(光学字符识别)技术被广泛应用于文档扫描、图片文字识别以及其他自动化数据提取任务。Tesseract作为一款强大的开源OCR引擎,在处理图像和PDF中的文本提取方面具有非常高的准确度和效率。本文将详细介绍如何使用Tess4J(Tesseract的Java接口)来处理图像文件和PDF文件中的文本内容,并讲解其实现原理。
一、Tess4J概述
Tess4J是Tesseract OCR引擎的Java封装,提供了便捷的API接口,使得Java开发者能够轻松地将OCR功能集成到自己的项目中。Tesseract本身是一个开源项目,由Google支持,广泛应用于文档扫描、图像文字提取等领域。Tess4J允许开发者通过Java代码调用Tesseract引擎,处理图片、PDF等文件中的文本。
Tesseract支持多语言的文本识别,包括中文、英文、法语、德语等,同时也支持自定义训练数据。它的高准确率使其成为OCR领域的领先工具之一。
二、Tess4J的安装与配置
1. 安装Tesseract
Tesseract的安装方式会根据操作系统的不同有所不同。以下是安装方法:
macOS:
brew install tesseract
Ubuntu/Linux:
sudo apt-get install tesseract-ocr
Windows:
Windows用户可以从Tesseract官网下载适用于Windows的安装包,并根据指引完成安装。
2. 配置TESSDATA_PREFIX
Tesseract需要语言训练数据文件来进行OCR识别。你可以从Tesseract的GitHub仓库下载所需的语言文件(例如eng.traineddata用于英文,chi_sim.traineddata用于简体中文)。下载完成后,需要将训练数据文件放置在Tesseract的tessdata目录下。
在Java中,需要设置环境变量TESSDATA_PREFIX来告诉Tesseract库训练数据的位置:
System.setProperty("jna.library.path", "/opt/homebrew/Cellar/tesseract/5.5.0/lib");
System.setProperty("TESSDATA_PREFIX", "/opt/homebrew/Cellar/tesseract/5.5.0/share/");
三、Tess4J的基本用法:处理图像文件
首先,我们来看如何使用Tess4J从图像中提取文本。下面的代码展示了如何用Tess4J加载图像并进行OCR识别:
private static void readImage() {// 设置Tesseract的路径File imageFile = new File("/path/to/your/image.png");// 创建Tesseract对象Tesseract tesseract = new Tesseract();tesseract.setDatapath("/opt/homebrew/Cellar/tesseract/5.5.0/share/tessdata"); // 设置Tesseract数据文件夹的路径tesseract.setLanguage("eng+chi_sim"); // 设置OCR使用的语言(如:英语 "eng",中文 "chi_sim")try {// 执行OCR并获取文本结果String result = tesseract.doOCR(imageFile);System.out.println(result); // 输出识别的文本} catch (TesseractException e) {System.err.println("OCR失败: " + e.getMessage());}
}
解析:
Tesseract:这是Tess4J提供的OCR引擎对象,我们可以通过它来加载图像并执行OCR识别。setDatapath:指定Tesseract的tessdata目录路径,里面存放的是语言训练数据。setLanguage:设置OCR识别所使用的语言,可以设置多个语言(例如:eng+chi_sim代表同时识别英语和简体中文)。doOCR:调用此方法可以执行OCR操作,并返回识别出来的文本。
四、Tess4J的进阶用法:从PDF中提取图像并进行OCR
Tesseract不仅可以处理图像文件,还能通过与其他工具结合,处理PDF文件中的文本。由于Tesseract本身无法直接读取PDF文件,因此我们可以借助PDFBox库,将PDF文件的每一页转换为图像,然后使用Tesseract进行OCR处理。
以下是一个完整的示例代码,展示了如何读取PDF文件中的图片并执行OCR识别:
private static void readPdf() {String filePath = "/path/to/your/file.pdf";Tesseract tesseract = new Tesseract();tesseract.setDatapath("/opt/homebrew/Cellar/tesseract/5.5.0/share/tessdata"); // 设置Tesseract数据文件夹的路径tesseract.setLanguage("eng+chi_sim"); // 设置OCR使用的语言(如:英语 "eng",中文 "chi_sim")try (PDDocument document = PDDocument.load(new File(filePath))) {int numberOfPages = document.getNumberOfPages();for (int i = 0; i < numberOfPages; i++) {PDPage page = document.getPage(i);// 提取PDF中的文字PDFTextStripper textStripper = new PDFTextStripper();textStripper.setStartPage(i + 1);textStripper.setEndPage(i + 1);String pageText = textStripper.getText(document);System.out.println("Page " + i + " Content: \n" + pageText + "\n");// 提取PDF中的图像PDResources resources = page.getResources();for (COSName xObjectName : resources.getXObjectNames()) {if (resources.isImageXObject(xObjectName)) {PDImageXObject imageObject = (PDImageXObject) resources.getXObject(xObjectName);BufferedImage bImage = imageObject.getImage();String result = tesseract.doOCR(bImage);System.out.println("Page " + (i + 1) + " Image Content: " + result);}}}} catch (Exception e) {System.err.println("OCR失败: " + e.getMessage());}
}
解析:
- PDFBox:通过
PDFBox将PDF文件中的每一页提取出来,并通过PDFTextStripper获取文本内容。 - 提取图像:使用
PDResources获取PDF中的所有XObject,然后判断其是否为图像,如果是,就提取图像并使用Tesseract进行OCR识别。 - OCR识别:通过
Tesseract对提取的图像进行OCR识别,并输出识别结果。
五、完整代码
import net.sourceforge.tess4j.Tesseract;
import net.sourceforge.tess4j.TesseractException;
import org.apache.pdfbox.cos.COSName;
import org.apache.pdfbox.pdmodel.PDDocument;
import org.apache.pdfbox.pdmodel.PDPage;
import org.apache.pdfbox.pdmodel.PDResources;
import org.apache.pdfbox.pdmodel.graphics.image.PDImageXObject;
import org.apache.pdfbox.text.PDFTextStripper;import javax.imageio.ImageIO;
import java.awt.image.BufferedImage;
import java.io.ByteArrayOutputStream;
import java.io.File;public class Tess4JTest {private static void readImage() {File imageFile = new File("/path/to/your/image.png");// 创建Tesseract对象Tesseract tesseract = new Tesseract();tesseract.setDatapath("/opt/homebrew/Cellar/tesseract/5.5.0/share/tessdata");tesseract.setLanguage("eng+chi_sim"); try {// 执行OCR并获取文本结果String result = tesseract.doOCR(imageFile);System.out.println(result); } catch (TesseractException e) {System.err.println("OCR失败: " + e.getMessage());}}private static void readPdf() {String filePath = "/path/to/your/file.pdf";// 创建Tesseract对象Tesseract tesseract = new Tesseract();tesseract.setDatapath("/opt/homebrew/Cellar/tesseract/5.5.0/share/tessdata"); tesseract.setLanguage("eng+chi_sim"); try (PDDocument document = PDDocument.load(new File(filePath))) {int numberOfPages = document.getNumberOfPages();for (int i = 0; i < numberOfPages; i++) {PDPage page = document.getPage(i);PDFTextStripper textStripper = new PDFTextStripper();textStripper.setStartPage(i + 1);textStripper.setEndPage(i + 1);String pageText = textStripper.getText(document);System.out.println("Page " + i + " Content: \n" + pageText + "\n");PDResources resources = page.getResources();for (COSName xObjectName : resources.getXObjectNames()) {if (resources.isImageXObject(xObjectName)) {PDImageXObject imageObject = (PDImageXObject) resources.getXObject(xObjectName);BufferedImage bImage = imageObject.getImage();try (ByteArrayOutputStream baos = new ByteArrayOutputStream()) {ImageIO.write(bImage, "png", baos);byte[] imageBytes = baos.toByteArray();System.out.println("Page " + i+1 + " Image size: " + imageBytes.length);}String result = tesseract.doOCR(bImage);System.out.println("Page " + i+1 + " Image Content: " + result);}}}} catch (Exception e) {System.err.println("OCR失败: " + e.getMessage());}}public static void main(String[] args) {System.setProperty("jna.library.path", "/opt/homebrew/Cellar/tesseract/5.5.0/lib");System.setProperty("TESSDATA_PREFIX", "/opt/homebrew/Cellar/tesseract/5.5.0/share/");readImage();readPdf();}
}
六、总结
Tess4J是Tesseract的Java接口,提供了强大的OCR识别能力,支持从图像、PDF文件中提取文本。通过合理配置环境并使用Tess4J的API,开发者可以轻松地实现OCR识别功能。结合PDFBox,我们还可以处理PDF文件中的图像,并对其进行文字提取。
本篇文章展示了如何配置Tess4J环境、如何从图像中提取文本,以及如何结合PDFBox和Tess4J进行PDF文件的OCR处理。通过这些步骤,开发者可以轻松地将OCR功能集成到Java项目中,实现高效的文字识别应用。
相关文章:
详细介绍Tess4J的使用:从PDF到图像的OCR技术实现
在当今的数字化时代,OCR(光学字符识别)技术被广泛应用于文档扫描、图片文字识别以及其他自动化数据提取任务。Tesseract作为一款强大的开源OCR引擎,在处理图像和PDF中的文本提取方面具有非常高的准确度和效率。本文将详细介绍如何…...
postgres源码学习之简单sql查询
postgres源码学习之sql查询 sql查询的主流程读取sql解析sql重写sql获得执行计划执行查询操作结果返回 sql查询的主流程 参考postgres的处理流程 由上一节,我们可以看到,当有新的连接通过权限认证之后,将进入等待接收sql语句,并执…...
C#项目05-猜数字多线程
本项目利用多线程,通过点击按钮猜数字, 知识点 线程 基本概念 进程:一组资源,构成一个正在运行的程序,这些资源包括地址空间、文件句柄以及程序启动需要的其他东西的载体。 线程:体现一个程序的真实执行情况, 线…...
前端504错误分析
前端出现504错误(网关超时)通常是由于代理服务器未能及时从上游服务获取响应。以下是详细分析步骤和解决方案: 1. 确认错误来源 504含义:代理服务器(如Nginx、Apache)在等待后端服务响应时超时。常见架构:前端 → 代理服务器 → 后端服务,问题通常出在代理与后端之间。…...
《C语言动态顺序表:从内存管理到功能实现》
1.顺序表 1.1 概念 顺序存储的线性表,叫顺序表。 1.2顺序表存放的实现方式 可以使用数组存储数据,可以实现逻辑上相连,物理内存上也相连。也可以使用malloc在堆区申请一片连续的空间,存放数据,实现逻辑上相连&#…...
通过API 调用本地部署 deepseek-r1 模型
如何本地部署 deepseek 请参考(windows 部署安装 大模型 DeepSeek-R1) 那么实际使用中需要开启API模式,这样可以无拘无束地通过API集成的方式,集成到各种第三方系统和应用当中。 上遍文章是基于Ollama框架运行了deepSeek R1模型…...
DeepSeek-学习与实践
1.应用场景 主要用于学习与使用DeepSeek解决问题, 提高效率. 2.学习/操作 1.文档阅读 文档 DeepSeek -- 官网, 直接使用 --- 代理网站 --- 极客智坊 https://poe.com/DeepSeek-R1 https://time.geekbang.com/search?qdeepseek -- 搜索deepseek的资料 资料 20250209DeepSeekC…...
DeepSeek和ChatGPT的全面对比
一、模型基础架构对比(2023技术版本) 维度DeepSeekChatGPT模型家族LLAMA架构改进GPT-4优化版本参数量级开放7B/35B/120B闭源175B位置编码RoPE NTK扩展ALiBiAttention机制FlashAttention-3FlashAttention-2激活函数SwiGLU ProGeGLU训练框架DeepSpeedMeg…...
无线网络安全配置指南:WPA、WPA2、WPA3及WAPI详解
对于做 Wi-Fi 的朋友,大家可能天天都需要配置各种加密和模式,但是有时候可能会一时忘记如何配置,基于日常的工作经验,总结了一篇文档:《无线网络安全配置指南:WPA、WPA2、WPA3及WAPI详解》,具体…...
撕碎QT面具(6):调节窗口大小后,控件被挤得重叠的解决方法
问题:控件重叠 分析原因:因为设置了最小大小,所以界面中的大小不会随窗口的变化而自动变化。 处理方案:修改mimumSize的宽度与高度为0,并设置sizePolicy为Expanding,让其自动伸缩。 结果展示(自…...
解锁机器学习核心算法 | K-平均:揭开K-平均算法的神秘面纱
一、引言 机器学习算法种类繁多,它们各自有着独特的优势和应用场景。前面我们学习了线性回归算法、逻辑回归算法、决策树算法。而今天,我们要深入探讨的是其中一种经典且广泛应用的聚类算法 —— K - 平均算法(K-Means Algorithm)…...
【Linux】匿名管道的应用场景-----管道进程池
目录 一、池化技术 二、简易进程池的实现: Makefile task.h task.cpp Initchannel函数: 创建任务: 控制子进程: 子进程执行任务: 清理收尾: 三、全部代码: 前言: 对于管…...
机器学习(1)安装Pytorch
1.安装命令 pip3 install torch torchvision torchaudio --index-url https://download.pytorch.org/whl/cu118 2.安装过程Log: Looking in indexes: https://download.pytorch.org/whl/cu118 Co…...
Linux 多Python版本统一和 PySpark 依赖 python 包方案
背景 Linux 服务器经常有多个Python版本,比如 Python2 有两个版本,Python3 有两个版本。在使用上容易混淆,而且有些需要新增一些 module 更容易,安装如果路径不统一,导致日常使用时,会出现找不到新安装mod…...
PostgreSQL的学习心得和知识总结(一百六十九)|深入理解PostgreSQL数据库之 Group By 键值消除 的使用和实现
目录结构 注:提前言明 本文借鉴了以下博主、书籍或网站的内容,其列表如下: 1、参考书籍:《PostgreSQL数据库内核分析》 2、参考书籍:《数据库事务处理的艺术:事务管理与并发控制》 3、PostgreSQL数据库仓库…...
DeepSeek是什么?两种模型的对比?
最近DeepSeek的风也是很大,它也是很火,那么DeepSeek是什么呢? 什么是DeepSeek? DeepSeek是一家专注通用人工智能(AGI)的中国科技公司,主攻大模型研发与应用。DeepSeek-R1是其开源的推理模型&a…...
跟着 Lua 5.1 官方参考文档学习 Lua (2)
文章目录 2.3 – Variables2.4 – Statements2.4.1 – Chunks2.4.2 – Blocks2.4.3 – Assignment2.4.4 – Control Structures2.4.5 – For Statement2.4.6 – Function Calls as Statements2.4.7 – Local Declarations 2.3 – Variables Variables are places that store v…...
Python基于循环神经网络的情感分类系统(附源码,文档说明)
博主介绍:✌IT徐师兄、7年大厂程序员经历。全网粉丝15W、csdn博客专家、掘金/华为云//InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ 🍅文末获取源码联系🍅 👇🏻 精彩专栏推荐订阅👇dz…...
Zookeeper应用案例-分布式锁-实现思路
以下是具体实现代码 第一步:注册锁节点 第二步:获取锁节点,如果自己是最小的节点,就获取权限 第三步:拿到锁就开始自己的业务逻辑 第四步:业务逻辑好了就要释放这把锁 第五步:重新注册监听&…...
java练习(32)
ps:题目来自力扣 环形链表 给你一个链表的头节点 head ,判断链表中是否有环。 如果链表中有某个节点,可以通过连续跟踪 next 指针再次到达,则链表中存在环。 为了表示给定链表中的环,评测系统内部使用整数 pos 来表…...
伯克利 CS61A 课堂笔记 10 —— Trees
本系列为加州伯克利大学著名 Python 基础课程 CS61A 的课堂笔记整理,全英文内容,文末附词汇解释。 目录 01 Trees 树 Ⅰ Tree Abstraction Ⅱ Implementing the Tree Abstraction 02 Tree Processing 建树过程 Ⅰ Fibonacci tree Ⅱ Tree Process…...
让编程变成一种享受-明基RD320U显示器
引言 作为一名有着多年JAVA开发经验的从业者,在工作过程中,显示器的重要性不言而喻。它不仅是我们与代码交互的窗口,更是影响工作效率和体验的关键因素。在多年的编程生涯中,我遇到过各种各样的问题。比如,在进行代码…...
10分钟上手DeepSeek开发:SpringBoot + Vue2快速构建AI对话系统
作者:后端小肥肠 目录 1. 前言 为什么选择DeepSeek? 本文技术栈 2. 环境准备 2.1. 后端项目初始化 2.2. 前端项目初始化 3. 后端服务开发 3.1. 配置文件 3.2. 核心服务实现 4. 前端服务开发 4.1. 聊天组件ChatWindow.vue开发 5. 效果展示及源…...
LeetCode 0624.数组列表中的最大距离:只关心最小最大值
【LetMeFly】624.数组列表中的最大距离:只关心最小最大值 力扣题目链接:https://leetcode.cn/problems/maximum-distance-in-arrays/ 给定 m 个数组,每个数组都已经按照升序排好序了。 现在你需要从两个不同的数组中选择两个整数ÿ…...
如何解决服务器端口被攻击:全面防护与快速响应
服务器端口被攻击是网络安全中常见的问题之一,尤其是当服务器暴露在公共网络上时,容易成为黑客的目标。攻击者可能通过扫描开放端口、利用漏洞或发动拒绝服务(DoS/DDoS)攻击来破坏服务器的正常运行。本文将详细介绍如何检测、防御…...
Golang深度学习
前言 在2009年,Google公司发布了一种新的编程语言,名为Go(或称为Golang),旨在提高编程效率、简化并发编程,并提供强大的标准库支持。Go语言的设计者们希望通过Go语言能够解决软件开发中的一些长期存在的问…...
Linux环境开发工具
Linux软件包管理器yum Linux下安装软件方式: 源代码安装rpm安装——Linux安装包yum安装——解决安装源、安装版本、安装依赖的问题 yum对应于Windows系统下的应用商店 使用Linux系统的人:大部分是职业程序员 客户端怎么知道去哪里下载软件࿱…...
JupyterNotebook高级使用:常用魔法命令
%%writefile test.py def Test(name):print("Test",name,"success")运行结果:就是在我们的文件目录下面创建了这个test.py文件,主要是认识一下这个里面的%%writefile表示创建新的文件,这个文件里面的内容就是上面我们定义…...
C++ Primer 类的作用域
欢迎阅读我的 【CPrimer】专栏 专栏简介:本专栏主要面向C初学者,解释C的一些基本概念和基础语言特性,涉及C标准库的用法,面向对象特性,泛型特性高级用法。通过使用标准库中定义的抽象设施,使你更加适应高级…...
【建设工程经济】2.1-2.2 经济效果评价的相关概念及指标体系
一、学前建议 学习内容主要有: ①财务评价的内容:盈利能力分析、偿债能力分析、财务可持续能力分析(财务生存能力); ②经济效果评价方法分类:确定性和不确定性评价、定量分析和定性分析、静态分析和动态分…...
