Java使用Tesseract-OCR實戰(zhàn)教程
Java使用Tesseract-OCR
光學字符識別(OCR, Optical Character Recognition)技術(shù)可以將圖像中的文本轉(zhuǎn)換為可編輯的文本。
Tesseract是目前最為流行的開源OCR引擎之一,支持多種語言和高效的文本識別。
本文將詳細介紹如何在Java中使用Tesseract-OCR進行文本提取,包括Tesseract-OCR的安裝、中文訓練庫的配置、依賴庫的引入以及具體的代碼實現(xiàn)。通過這個過程,我們將演示如何從視頻幀中提取文本。
Tesseract-OCR安裝
首先,我們需要在系統(tǒng)上安裝Tesseract-OCR??梢酝ㄟ^以下鏈接下載適用于Windows的安裝包:
下載完成后,運行安裝程序并選擇安裝目錄,默認下一步安裝即可。
配置中文訓練庫
為了使Tesseract能夠識別中文,我們需要下載中文簡體的訓練庫文件chi_sim.traineddata
,并將其放置在Tesseract的tessdata
目錄下。
例如:
makefile D:\Program Files\Tesseract-OCR\tessdata
可以從以下鏈接下載中文訓練庫:
更多訓練庫可以在Tesseract官方GitHub倉庫找到。
引入依賴
為了在Java中使用Tesseract,我們需要引入tess4j
庫。tess4j
是一個Java的Tesseract API封裝,可以方便地在Java項目中使用Tesseract。此外,為了處理視頻幀,我們還需要javacv
庫。
以下是需要在Maven項目中引入的依賴:
```xml <dependency> <groupId>net.sourceforge.tess4j</groupId> <artifactId>tess4j</artifactId> <version>5.3.0</version> </dependency> <!-- JavaCV: Java interface to OpenCV, FFmpeg, and more --> <dependency> <groupId>org.bytedeco</groupId> <artifactId>javacv-platform</artifactId> <version>1.5.7</version> </dependency>
代碼實現(xiàn)
接下來,我們將實現(xiàn)一個Java類VideoTextExtractor
,該類用于從視頻中提取文本。
完整代碼如下:
```java import net.sourceforge.tess4j.TesseractException; import org.bytedeco.javacv.FFmpegFrameGrabber; import org.bytedeco.javacv.Frame; import org.bytedeco.javacv.Java2DFrameUtils; import javax.imageio.ImageIO; import java.awt.*; import java.awt.image.BufferedImage; import java.io.File; import java.util.ArrayList; import java.util.LinkedHashSet; import java.util.Set; public class VideoTextExtractor { // Tesseract-OCR安裝路徑 public static final String pathToTessdataFolder = "D:\\Program Files\\Tesseract-OCR\\tessdata\\"; // 加載視頻 public static final String pathToVideoFile = "C:\\Users\\lixiewen\\Documents\\oCam\\錄制_2023_05_31_09_39_51_172.mp4"; // 解析結(jié)果 public static final String resultFile = "E:\\tmp\\tmp.txt"; public static void main(String[] args) throws TesseractException { extracted(); } private static void extracted() { // 設置Tesseract OCR庫的路徑 File tessDataFolder = new File(pathToTessdataFolder); System.setProperty("TESSDATA_PREFIX", tessDataFolder.getAbsolutePath()); FFmpegFrameGrabber grabber = new FFmpegFrameGrabber(pathToVideoFile); try { grabber.start(); Set<String> set = new LinkedHashSet<>(); // 遍歷視頻幀 int lengthInFrames = grabber.getLengthInFrames(); for (int i = 0; i < lengthInFrames; i++) { System.out.println("進度 " + i + " / " + lengthInFrames); try { Frame frame = grabber.grabImage(); if (frame == null) continue; BufferedImage bufferedImage = Java2DFrameUtils.toBufferedImage(frame); // 將幀轉(zhuǎn)換為灰度圖像 BufferedImage grayImage = new BufferedImage(bufferedImage.getWidth(), bufferedImage.getHeight(), BufferedImage.TYPE_BYTE_GRAY); Graphics2D graphics = grayImage.createGraphics(); graphics.drawImage(bufferedImage, 0, 0, null); graphics.dispose(); // 創(chuàng)建臨時文件保存圖像 File tempImageFile = File.createTempFile("frame", ".png"); ImageIO.write(grayImage, "png", tempImageFile); Tesseract tesseract = getTesseract(tessDataFolder); String result = tesseract.doOCR(tempImageFile); set.add(result); // 刪除臨時文件 tempImageFile.delete(); } catch (Exception e) { e.printStackTrace(); } } File file = new File(resultFile); FileUtils.write2File(file, new ArrayList<>(set)); grabber.stop(); } catch (Exception e) { e.printStackTrace(); } } private static Tesseract getTesseract(File tessDataFolder) { // 使用Tesseract OCR進行文字識別 Tesseract tesseract = new Tesseract(); // 設置中文訓練庫 tesseract.setLanguage("chi_sim"); tesseract.setDatapath(tessDataFolder.getAbsolutePath()); return tesseract; } }
免安裝方式
如果不希望安裝Tesseract-OCR,可以直接在項目中引入訓練庫。這種方式適合希望更方便地管理依賴的開發(fā)者。
- 引入Maven依賴
- 在代碼中引入訓練庫
```java import net.sourceforge.tess4j.Tesseract; public class OCRUtil { public static ITesseract getTesseract() throws Exception { // 使用 Tesseract 識別文本 ITesseract tesseract = new Tesseract(); // 設置訓練數(shù)據(jù)文件夾路徑 tesseract.setDatapath("src/main/resources/traineddata"); // 設置為中文簡體 tesseract.setLanguage("chi_sim"); return tesseract; } }
優(yōu)化與提升
在實際應用中,我們可以對視頻幀的處理和OCR識別進行優(yōu)化,以提高識別效率和準確性。以下是一些建議:
- 圖像預處理:在進行OCR識別之前,可以對圖像進行去噪、二值化、旋轉(zhuǎn)校正等預處理,以提高識別率。
- 多線程處理:對于長時間的視頻處理,可以使用多線程來提高幀處理速度。
- 自定義訓練數(shù)據(jù):如果默認的訓練數(shù)據(jù)效果不理想,可以通過Tesseract的訓練工具自定義訓練數(shù)據(jù),以提高特定場景下的識別準確率。
- 結(jié)果后處理:OCR識別的文本可能包含一些噪聲字符,可以通過正則表達式等方法對結(jié)果進行清洗和校正。
以下是一個優(yōu)化后的圖像預處理示例:
```java // 轉(zhuǎn)換為灰度圖像 BufferedImage grayImage = new BufferedImage(image.getWidth(), image.getHeight(), BufferedImage.TYPE_BYTE_GRAY); Graphics2D graphics = grayImage.createGraphics(); graphics.drawImage(image, 0, 0, null); graphics.dispose(); // 二值化處理 for (int y = 0; y < grayImage.getHeight(); y++) { for (int x = 0; x < grayImage.getWidth(); x++) { int rgb = grayImage.getRGB(x, y); int gray = (rgb & 0xff); gray = gray > 128 ? 255 : 0; grayImage.setRGB(x, y, (gray << 16) | (gray << 8) | gray); } } return grayImage; }
總結(jié)
通過本文的介紹,我們詳細講解了如何在Java中使用Tesseract-OCR進行文本提取的全過程。包括Tesseract-OCR的安裝、中文訓練庫的配置、依賴庫的引入以及具體的代碼實現(xiàn),并提供了一些優(yōu)化建議。
這些內(nèi)容能幫助您在實際項目中更好地應用Tesseract-OCR進行文本識別。
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
詳解Kotlin:forEach也能break和continue
這篇文章主要介紹了詳解Kotlin:forEach也能break和continue的相關(guān)資料,需要的朋友可以參考下2017-06-06SpringBoot字段注入和構(gòu)造函數(shù)注入的區(qū)別及說明
這篇文章主要介紹了SpringBoot字段注入和構(gòu)造函數(shù)注入的區(qū)別及說明,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2025-04-04springboot druid數(shù)據(jù)庫配置密碼加密的實現(xiàn)
Druid是阿里開發(fā)的數(shù)據(jù)庫連接池,本文主要介紹了springboot druid數(shù)據(jù)庫配置密碼加密的實現(xiàn),具有一定的參考價值,感興趣的可以了解一下2024-06-06Spring實戰(zhàn)之XML與JavaConfig的混合配置詳解
大家都知道Spring的顯示配置方式有兩種,一種是基于XML配置,一種是基于JavaConfig的方式配置。那么下這篇文章主要給大家分別介紹如何在JavaConfig中引用XML配置的bean以及如何在XML配置中引用JavaConfig,需要的朋友可以參考下。2017-07-07Spring注解@RestControllerAdvice原理解析
這篇文章主要介紹了Spring注解@RestControllerAdvice原理解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2019-11-11JavaWeb ServletConfig作用及原理分析講解
ServletConfig對象,叫Servlet配置對象。主要用于加載配置文件的初始化參數(shù)。我們知道一個Web應用里面可以有多個servlet,如果現(xiàn)在有一份數(shù)據(jù)需要傳給所有的servlet使用,那么我們就可以使用ServletContext對象了2022-10-10