作者:虚坏叔叔
博客:https://xuhss.com
早餐店不会开到晚上,想吃的人早就来了!😄
Python利用OCR提取图片中的文字
很多软件内置了OCR
功能,即图片提取文字功能。有些是免费提供给大家使用,但有些是收费的。不管是免费的还是收费的,终究逃离不了隐私问题。用别人的OCR
,总得把图片传到对方的服务器。今天我们使用Python
开发一个OCR
软件,如下图所示。
一、 安装环境
本文基于PaddleOCR
搭建本地开发图片提取文字软件,因此需要安装PaddlePaddle
环境。
1.1 安装PaddlePaddle
如果您的机器有安装CUDA9
或CUDA10
,推荐安装GPU
版本的PaddlePaddle
,享受更快的运行速度。运行以下命令安装:
python -m pip install paddlepaddle-gpu -i https://mirror.baidu.com/pypi/simple
如果您的机器只有CPU
环境,运行速度会稍微慢一点。请运行以下命令安装
python -m pip install paddlepaddle -i https://mirror.baidu.com/pypi/simple
1.2 安装PaddleOCR whl包
有了PaddlePaddle
环境后,接下来安装PaddleOCR库,推荐使用2.0.1+版本:
pip install "paddleocr>=2.0.1"
注意:
对于
Windows
环境用户:直接通过pip
安装的shapely
库可能出现[winRrror 126]
找不到指定模块的问题。建议从这里https://www.lfd.uci.edu/~gohlke/pythonlibs/#shapely下载shapely
安装包完成安装。
二、调用OCR
调用OCR
过程非常简单,导入PaddleOCR
后,直接创建PaddleOCR
对象:
from paddleocr import PaddleOCR
ocr = PaddleOCR(use_angle_cls=True, lang="ch")
ocr.ocr(img_path, cls=True)
第2
行代码中,use_angle_cls
参数用于确定是否使用角度分类模型,即是否识别垂直方向的文字。lang
参数表示识别的语言,我们传入ch
,表示识别汉字。
第3
行代码中, img_path
表示图片路径,cls
表示是否使用角度分类模型。
三、开发界面
有了以上代码就可以完成OCR
功能,但使用起来还不够方便,我们进一步将OCR
功能封装成软件,便于交互。首先安装PyQT5
:
pip install PyQt5
接下来调用PyQT5完成界面交互,篇幅原因,这里只显示调用ocr部分代码,读者可以直接拉到最后获取完整源码。
class OCRGUI(QWidget):# 其他代码略...def run_ocr(self, img_path):result = self.ocr.ocr(img_path, cls=True)self.text.clear() txts = [line[1][0] for line in result]for txt in txts:self.text.insertPlainText(txt + "\n")self.loading.hide()
四、总结
- 本文完成OCR提取图片中的文字。
- 如果觉得文章对你有用处,记得
点赞
收藏
转发
一波哦,博主也支持为铁粉丝制作专属动态壁纸哦~
💬 往期优质文章分享
- C++ QT结合FFmpeg实战开发视频播放器-01环境的安装和项目部署
- 解决QT问题:运行qmake:Project ERROR: Cannot run compiler ‘cl‘. Output:
- 解决安装QT后MSVC2015 64bit配置无编译器和调试器问题
- Qt中的套件提示no complier set in kit和no debugger,出现黄色感叹号问题解决(MSVC2017)
- Python+selenium 自动化 - 实现自动导入、上传外部文件(不弹出windows窗口)
🚀 优质教程分享 🚀
- 🎄如果感觉文章看完了不过瘾,可以来我的其他 专栏 看一下哦~
- 🎄比如以下几个专栏:Python实战微信订餐小程序、Python量化交易实战、C++ QT实战类项目 和 算法学习专栏
- 🎄可以学习更多的关于C++/Python的相关内容哦!直接点击下面颜色字体就可以跳转啦!
学习路线指引(点击解锁) | 知识定位 | 人群定位 |
---|---|---|
🧡 Python实战微信订餐小程序 🧡 | 进阶级 | 本课程是python flask+微信小程序的完美结合,从项目搭建到腾讯云部署上线,打造一个全栈订餐系统。 |
💛Python量化交易实战 💛 | 入门级 | 手把手带你打造一个易扩展、更安全、效率更高的量化交易系统 |
❤️ C++ QT结合FFmpeg实战开发视频播放器❤️ | 难度偏高 | 分享学习QT成品的视频播放器源码,需要有扎实的C++知识! |
💚 游戏爱好者九万人社区💚 | 互助/吹水 | 九万人游戏爱好者社区,聊天互助,白嫖奖品 |
💙 Python零基础到入门 💙 | Python初学者 | 针对没有经过系统学习的小伙伴,核心目的就是让我们能够快速学习Python的知识以达到入门 |
🚀 资料白嫖,温馨提示 🚀
关注下面卡片即刻获取更多编程知识,包括各种语言学习资料,上千套PPT模板和各种游戏源码素材等等资料。更多内容可自行查看哦!