利用OCR识别图像中的英文和文字

news/2024/11/19 10:38:10/

一、Tesseract—OCR简介

将图片翻译成文字一般称为光学文字识别(Optical Character Recognition,OCR)。可以实现OCR的底层并不多,目前很多库都是实用共同的几个底层OCR库,或者是在上面进行定制。
Tesseract是一个OCR库,目前由Google赞助。Tesseract是目前公认最优秀、最精确的开源OCR系统

二、下载

https://digi.bib.uni-mannheim.de/tesseract/

1.尽量不要下载dev(开发中的版本),alpha(内部测试版,一般不向外部发布,会有很多Bug),beta(公测版本,即针对所有用户公开的测试版本)等版本。

2.建议下载最新稳定版本:
tesseract-ocr-w64-setup-v5.0.1.20220118.exe
下面进行傻瓜式安装
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

三、下载pytesseract库

在anaconda里面进行安装,然后直接使用anaconda环境就可以。在这里插入图片描述

四、识别英文

#导入PIL,pytesseract库
import pytesseract
from PIL import Imagepytesseract.pytesseract.tesseract_cmd = r'D:\Python\tesseract.exe'#读取待识别的图片
image = Image.open("7.jpg");
#将图片识别为英文文字
text = pytesseract.image_to_string(image)
#输出识别的文字
print(text)

下面是“7.jpg”文件
请添加图片描述
下面是运行结果
在这里插入图片描述

五、识别中文

tesseract默认安装可能不带中文简体识别包,需要额外下载。
在github中直接搜索tesseract,下载tessdata文件到Tesseract安装文件中,
,下载

#导入PIL,pytesseract库
import pytesseract
from PIL import Imagepytesseract.pytesseract.tesseract_cmd = r'D:\Python\tesseract.exe'#读取待识别的图片
image = Image.open("8.jpg");
#将图片识别为英文文字
text = pytesseract.image_to_string(image, lang='chi_sim')
#输出识别的文字
print(text)

下面是“8.jpg”文件
请添加图片描述
下面是识别结果
在这里插入图片描述

六、如何识别单个字符

运行过上面代码的同学,如果把输入图像换为单个字母或者文字的图像就会输出失败,例如下面的图片,这里是因为OCR是用作识别多文字的情景,使用单个文字会被认为是图片,就会自动跳过。
请添加图片描述
在这里插入图片描述
这里怎么解决呢
改为如下代码

#导入PIL,pytesseract库
import pytesseract
from PIL import Imagepytesseract.pytesseract.tesseract_cmd = r'D:\Python\tesseract.exe'#读取待识别的图片
image = Image.open("9.jpg");
#将图片识别为英文文字
cong = r'--psm 10'
text = pytesseract.image_to_string(image, config=cong)
#输出识别的文字
print(text)

添加

cong = r’–psm 10’

text = pytesseract.image_to_string(image, config=cong)

就可以输出了
在这里插入图片描述


http://www.ppmy.cn/news/404537.html

相关文章

超轻量级中文ocr,OcrLiteOnnx文字识别

原项目地址:https://github.com/benjaminwan/OcrLiteOnnx 本文是基于原项目编译好后的OcrLiteOnnx文字识别系统,可以实现提取图片中的文字及文字中心点坐标等功能。 相较于Tesseract这个OCR来说文字识别的准确度要高很多,识别速度也会快&…

c++初始化vector的几种方法

在C中,vector是一种动态数组,可以在运行时自由添加、删除元素。初始化vector是创建一个vector对象并为其分配内存空间的过程。以下是C中初始化vector的几种方法: 默认构造函数 使用默认构造函数创建一个空的vector,如下所示&…

OCR文字识别软件哪个好?7大文字识别软件

由于从各种文档中提取文本的需求非常普遍,许多办公软件或公司都提供了OCR工具。在本文中,我们为您推出了一系列功能强大且易于使用的最佳 OCR 软件。 什么是 OCR 软件? OCR 软件是一种程序或工具,可以使用光学字符识别技术识别数…

Android集成百度OCR图片文字识别——总结

近期由于工作内容的需要,我要给项目集成一个图片文字识别功能,据说百度的不错,所以今天写一个关于百度OCR的集成总结,以便以后再次使用不用去看官方文档。 首先肯定是要在百度管理平台注册账号并登录,然后照常去添加应…

超轻量级中文OCR,支持竖排文字识别、ncnn推理,总模型仅17M

整理 | AI科技大本营 光学字符识别(OCR)技术已经得到了广泛应用。比如发票上用来识别关键字样,搜题App用来识别书本上的试题。 近期,这个叫做chineseocr_lite的OCR项目开源了,这是一个超轻量级中文ocr,支持…

百度文字识别(OCR)服务-傻瓜式

1.注册百度账号 进入百度开发者中心-百度智能云,直接按图操作,领取免费资源、创建应用。少说话,开撸 百度开发者中心-汇聚、开放、助力、共赢百度开发者中心是一个面向开发者的知识分享平台,专注于为开发者打造一个有温度的技术…

百度OCR文字识别在Android的应用(一)纯图版,超详细

百度OCR文字识别在Android的应用 最近OCR越来越火,大部分项目上面都会集成图像识别的功能,于是就入坑亲测了一下,过程中也遇到过一些困难,不过都解决了,下面是集成的一些经验与大家分享一下:用步骤来描述。…

ABBYY最新15版同时可用OCR文字识别和PDF编辑

ABBYY FineReader是一款超强大的OCR识别软件,ABBYY 轻松将任意文档转换成您需要的可编辑、引用、归档、搜索或分享的信息!ABBYY FineReader 通过将纸质文档、PDF文件和数码照片中的文字转换成可编辑、可搜索的文件,让您的电脑处理更具效率&am…