大家好

今天给大家介绍一个超级简单且强大的OCR文本识别工具:easyocr.

这个模块支持70多种语言的即用型OCR,包括中文,日文,韩文和泰文等。Python学习资料点击免费领取

下面是这个模块的实战教程。

1.准备

pip install easyocr
复制代码

它会安装除了模型文件之外的所有依赖,模型文件则会在运行代码的时候下载。

对于Windows,如果在安装 Torch 或 Torchvision 时报错了,请按照pytorch.org 的官方说明安装 Torch 和 Torchvision。

如果你想使用显卡进行计算,你需要搜索下载CUDA,并在Pytorch网站上,确保选择正确的CUDA版本。如果仅打算在CPU模式下运行,请选择CUDA = None。

2.实战教程

这个模块用起来真的非常简单,三行代码完事了:

import easyocr
reader = easyocr.Reader(['ch_sim','en'])
result = reader.readtext('test.png')
复制代码

运行的过程中会安装所需要的模型文件,像下面这样:

不过它的下载速度非常慢,而且经常会失败,因此这里给出第二个解决方案:先下载好模型文件,再将其放置到所需要的位置:

文字检测模型(CRAFT)(必须)

pythondict.com/go/?url=htt…

中文(简体)模型(识别中文必须)

pythondict.com/go/?url=htt…

中国(传统)模型

pythondict.com/go/?url=htt…

拉丁模型

pythondict.com/go/?url=htt…

日本模型

pythondict.com/go/?url=htt…

韩文模型

pythondict.com/go/?url=htt…

泰文模型

pythondict.com/go/?url=htt…

阿拉伯文模型

pythondict.com/go/?url=htt…

下载完模型后,将文件放到下面这个位置。

Windows:C:\Users\用户名.EasyOCR\model Linux:~/ .EasyOCR / model

如下图所示:

重新执行脚本不会再提醒下载模型了:

import easyocr
reader = easyocr.Reader(['ch_sim'])
result = reader.readtext('test.png')
print(result)
复制代码

我随便截了一个直播弹幕的图片保存在脚本所在的文件夹下,命名为test.png:

结果如下:

基本上所有应该识别的文字都识别出来了,效果非常不错。

另外也可以看到,输出采用列表格式,每个item分别表示对应文字的边界框,识别文本结果和置信度。

这个模块还能识别多语种的情况:

我将这张图片命名为test2.jpg,修改代码中对应的图片名称:

import easyocr
reader = easyocr.Reader(['ch_sim','en'])
result = reader.readtext('test2.jpg')
print(result)
复制代码

效果如下:

这张图片很复杂,而且是中英文混杂在一起的情况,但是可以看到模型除了左上角的水印,图片中的文字基本都是识别出来了,尽管有部分文字识别错误,但还在可以接受的范围之内。

不过需要注意的是,虽然可以一次性识别许多种语言,但并非所有语言都可以一起用,通常是公共语言和一个特殊语种可以一起识别,相互兼容,比如英语和日语。

如果你的电脑没有GPU或者显存不足,可以加一个gpu=false的参数仅使用CPU运行:

reader = easyocr.Reader(['ch_sim','en'], gpu = False)
复制代码

另外,这个模块还支持直接使用命令行运行,相当方便,大家可以试试:

easyocr -l ch_sim en -f test.png --detail=1 --gpu=True
复制代码

我们的文章到此就结束啦,如果你喜欢今天的Python 实战教程,给文章点个赞吧

教你3行Python代码,识别图片中的任意语言文字相关推荐

  1. Easyocr - 3行代码识别图片中的任意语言文字

    AI派在读学生小姐姐Beyonce Java实战项目练习群 长按识别下方二维码,按需求添加 扫码添加Beyonce小姐姐 扫码关注 进Java学习大礼包 今天给大家介绍一个超级简单且强大的OCR文本识 ...

  2. 50行python代码打造一款女友监控器_手把手教你50行Python代码,给心目中的女友微博秒评论...

    突然觉得,现在发微博已经成为当代青年的潮流,或分享自拍美照,或分享美食美景,小编的女朋友也不例外,平时爱分享一些我俩生活的趣事. 但是她最近开始给我抱怨我从来不给她的微博评论,我作为骨灰级" ...

  3. 人脸检测颜值源代码python_50行Python代码识别杨超越的颜值

    行哥又又又又拿杨超越做封面了,只因为昨天群里有小伙伴想学下人脸识别 但是如果要详细介绍的话,那这个故事得从opencv的那个夏天说起,对于python小白来说,门槛有点高.所以行哥今天先给大家介绍一个 ...

  4. 50行Python代码识别杨超越的颜值

    行哥又又又又拿杨超越做封面了,只因为昨天群里有小伙伴想学下人脸识别 但是如果要详细介绍的话,那这个故事得从opencv的那个夏天说起,对于python小白来说,门槛有点高.所以行哥今天先给大家介绍一个 ...

  5. zip密码忘记怎么办?手把手教你几行Python代码来解决,操作简单有手就行

    当现在zip压缩包已经广泛地使用,zip文件不仅仅节约了电脑内存,还可以给隐私内容设置密码.但是,要是忘记了密码,特别是十分重要的文件,那可真的芭比Q了. 解决它! 你可能想过,把有可能的密码都试一遍 ...

  6. python图片内容长度识别_教你如何用几行Python代码识别图片文字--就是这么简单!...

    今天给大家分享的主题是用百度的接口实现图片的文字识别. ​ 环境和配置要求 整体是用 Python 实现,所需要使用的第三方库包括 aip . PIL . keyboard . pyinstaller ...

  7. python做桌面软件 代码隐藏_桌面杂乱?教你50行Python代码一键整理桌面!

    我们每天上班会有很多文件来不及处理,全部都在桌面上堆放在了一起,久而久之,就造成了桌面非常的混乱,如下图所示: 乱糟糟的桌面,让心情也会潜移默化的变得烦躁,更重要的是,它会让我们的工作效率变的非常的低 ...

  8. 1行Python代码识别身份证信息,还能自动告警,YYDS

    大家好,这里是程序员晚枫. 录入身份证信息是一件繁琐的工作,如果可以自动识别并且录入系统,那可真是太好了. 今天我们就来学习一下,如何自动识别身份证信息并且录入系统~ 识别身份证信息 识别身份证信息的 ...

  9. 9行Python代码去除图片中的数字水印

    近期会议: 2020.11.28-29全国高校大数据专业教学研讨与教师培训会议 2020年12月3-5日"Python 数据分析.挖掘与可视化"教师研修班通知 好消息:" ...

最新文章

  1. ABAP语言常用的系统字段及函数
  2. 在 ubuntu 20.04 LTS 上安装 ROS2 执行 rosdep update 命令时出现的问题的解决办法
  3. CVPR 2019 | NAS-FPN:基于自动架构搜索的特征金字塔网络
  4. echarts鼠标事件以及自定义数据获取
  5. c构造函数和析构函数_C ++构造函数和析构函数| 查找输出程序| 套装3
  6. 2020-1024=996,2020年程序员还会难吗?
  7. 服务器系统性能计数器,MSRS 2008 Windows Service 性能对象的性能计数器
  8. 【深入理解JVM】JVM的五大运行时数据区域
  9. 14.5【结构体指针编程】小科同学学习了数组和结构体,认真进行编程练习,顺利完成了老师布置的20道课外编程题后,他想起了科比20年的职业生涯数据。
  10. 行政区域村级划分数据库_两区划定数据库规范标准
  11. c语言源代码三角函数大全,【C语言及程序设计】项目2-9-3:编制三角函数表
  12. EXIT: Extrapolation and Interpolation-based Neural Controlled Differential Equations for Time-series
  13. vue+file-saver+xlsx 封装导出Excel表格方法
  14. 淘宝直通车优化,自定义人群,ROI提升
  15. html网页的框架标记分别有,新手入门前端,应该知道HTML框架排版标记标签大全...
  16. Box2D 源码编译
  17. Intel汇编-传送MMX整数
  18. uniapp延迟执行_【 vue / uniapp 】延迟加载数据的特殊处理
  19. 在公司三年跌宕起伏的经历
  20. MySQL存储引擎 优化 索引问题

热门文章

  1. SQL2000恢复单MDF数据库过程
  2. 地理坐标转换 - 地理信息系统(3)
  3. 小啊呜产品读书笔记001:《邱岳的产品手记-09》第17讲 产品经理如何获得非权力性的影响力 第18讲 产品案例分析:WWFTogether的情怀设计
  4. Java Record 的一些思考 - 默认方法使用以及基于预编译生成相关字节码的底层实现
  5. 生物信息百Jia软件(二十):lumpy
  6. python卸载没卸载干净导致再次安装失败
  7. 解决Vue前后端跨域问题的多种方式
  8. ServiceNow代码规范
  9. 日撸 Java 三百行(20 天: 过去10日总结)
  10. 微信公众平台的TOKEN安全验证