Tesseract-OCR引擎 入门

OCR(Optical Character Recognition):光学字符识别,是指对图片文件中的文字进行分析识别,获取的过程。

Tesseract:开源的OCR识别引擎,初期Tesseract引擎由HP实验室研发,后来贡献给了开源软件业,后经由Google进行改进,消除bug,优化,重新发布。当前版本为3.01.

项目地址为:http://code.google.com/p/tesseract-ocr


Windows 命令行使用Tesseract-OCR引擎识别验证码:

1、下载安装Tesseract-OCR引擎(3.0版本+才支持中文识别)

tesseract-ocr-setup-3.01-1.exe

下载完后进行安装,默认情况下安装程序会给你配置系统环境变量,以指向安装目录(之后可以通过DOS界面在任意目录运行tesseract)。安装完成后目录如下:

附录:

 tessdata 目录存放的是语言字库文件,和在命令行界面中可能用到的参数所对应的文件.  这个安装程序默认包含了英文字库。

如果想能识别中文,可以到http://code.google.com/p/tesseract-ocr/downloads/list下载对应的语言的字库文件. 

简体中文字库文件下载地址为:http://tesseract-ocr.googlecode.com/files/chi_sim.traineddata.gz 下载完成后解压,然后将该文件剪切到tessdata目录下去就可以了。


2、使用Tessract-OCR引擎识别验证码

打开DOS界面,输入tesseract:


如果出现如上输出,表示安装正常。

我准备了一张验证码code.jpg放在D盘根目录下 ,上图:


结果为:



附录:

Usage:tesseract imagename outputbase [-l lang] [-psm pagesegmode] [configfile...]
pagesegmode values are:
0 = Orientation and script detection (OSD) only.
1 = Automatic page segmentation with OSD.
2 = Automatic page segmentation, but no OSD, or OCR
3 = Fully automatic page segmentation, but no OSD. (Default)
4 = Assume a single column of text of variable sizes.
5 = Assume a single uniform block of vertically aligned text.
6 = Assume a single uniform block of text.
7 = Treat the image as a single text line.
8 = Treat the image as a single word.
9 = Treat the image as a single word in a circle.
10 = Treat the image as a single character.
-l lang and/or -psm pagesegmode must occur before anyconfigfile.


tesseract imagename outputbase [-l lang] [-psm pagesegmode] [configfile...]

tesseract    图片名  输出文件名 -l 字库文件 -psd pagesegmode 配置文件

例如:

tesseract code.jpg result  -l chi_sim -psd 7 nobatch

-l chi_sim 表示用简体中文字库(需要下载中文字库文件,解压后,存放到tessdata目录下去,字库文件扩展名为  .raineddata 简体中文字库文件名为:  chi_sim.traineddata)

-psd 7 表示告诉tesseract code.jpg图片是一行文本  这个参数可以减少识别错误率.  默认为 3

configfile 参数值为tessdata\configs 和  tessdata\tessconfigs 目录下的文件名

转载于:https://www.cnblogs.com/springside6/archive/2012/01/11/2525113.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 Python 实现实时 OCR 可以使用 Python 的视觉库 OpenCV 和 OCRTesseract。 首先,需要安装 OpenCV 和 Tesseract。接着,使用 OpenCV 读取视频流或者实时摄像头输入。然后,使用 OpenCV 对输入图像进行处理,将其转换为黑白图像或灰度图像,以便 Tesseract 能够更好地识别文本。 接下来,使用 Tesseract 识别图像的文本。可以使用 Tesseract 的 Python 封装库 pytesseract 来方便地调用 TesseractOCR 功能。例如: ```python import cv2 import pytesseract # 读取视频流或实时摄像头输入 cap = cv2.VideoCapture(0) while True: # 读取一帧图像 ret, frame = cap.read() # 将图像转换为灰度图像 gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY) # 使用 Tesseract 识别图像的文本 text = pytesseract.image_to_string(gray) print(text) ``` 上面的代码实现了从视频流或实时摄像头输入读取图像,然后使用 Tesseract 识别图像的文本。你可以根据需要调整代码的参数,以提高 OCR 的准确性。 ### 回答2: 实时OCR是一种使用光学字符识别(OCR)技术,在短时间内实现对文本内容实时识别的方法。OCR技术可以通过对图像或视频的文字进行扫描和解析,将其转化为电子文本。 要实现实时OCR,我们可以使用Python编程语言并结合一些开源库来完成。首先,我们需要安装和导入Tesseract OCR库,它是一个广泛使用的OCR引擎。 然后,可以使用Python的OpenCV库来进行图像处理。我们可以通过打开摄像头和读取实时视频流来捕捉图像。接下来,我们需要对捕捉到的图像进行预处理,例如灰度化、二值化、去除噪声等。这些预处理步骤可以提高OCR的准确性。 一旦图像预处理完成,我们就可以使用Tesseract OCR库来进行实时文本识别。通过将预处理的图像传递给OCR引擎,我们可以获得相应的文字结果。然后,我们可以在屏幕上显示识别出的文本,并进行后续处理或存储。 以下是一个简单的实时OCR Python代码示例: ```python import cv2 import pytesseract # 定义摄像头 cap = cv2.VideoCapture(0) # 设置OCR引擎 pytesseract.pytesseract.tesseract_cmd = r"C:\Program Files\Tesseract-OCR\tesseract.exe" while True: # 读取摄像头帧 ret, frame = cap.read() # 图像预处理 gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY) gray = cv2.GaussianBlur(gray, (5, 5), 0) _, threshold = cv2.threshold(gray, 0, 255, cv2.THRESH_BINARY + cv2.THRESH_OTSU) # OCR识别 result = pytesseract.image_to_string(threshold, lang='eng') # 显示识别结果 cv2.putText(frame, result, (10, 50), cv2.FONT_HERSHEY_SIMPLEX, 1, (0, 255, 0), 2) cv2.imshow('OCR', frame) # 退出循环 if cv2.waitKey(1) & 0xFF == ord('q'): break # 释放摄像头 cap.release() cv2.destroyAllWindows() ``` 这是一个简单的入门示例,你可以根据实际需求进行更进一步的优化。例如,你可以调整预处理步骤的参数,改善识别的准确性。你也可以添加其他功能,例如保存识别结果或将结果发送到其他系统。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值