51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 372|回复: 1
打印 上一主题 下一主题

[python] 使用Python代码获取图片中的文字信息

[复制链接]
  • TA的每日心情
    无聊
    5 小时前
  • 签到天数: 968 天

    连续签到: 1 天

    [LV.10]测试总司令

    跳转到指定楼层
    1#
    发表于 2023-5-19 10:59:55 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
    最近工作中有需求需要用python对图片中的文字进行识别,调研了一下,选择了tesseract,目前在github上有50.5k个star!python可以调用,安装也十分方便,pip install pytesseract 即可。如果没有Pillow 包,还需要执行pip install Pillow。
      核心代码
      读取图片中文字信息的核心api如下:
      from PIL import Image
      import pytesseract
      captcha_text = pytesseract.image_to_string(Image.open("d:/tmp/img4.png"), lang='chi_sim')
      print(captcha_text)


      上面这段代码中需要解释的是如果图片中有中文字符则需要添加参数lang='chi_sim',并在安装的过程中添加识别中文的字符库,后面会讲到!
      运行代码遇到的问题
      直接运行上面的代码,会遇到下面的问题:
      raise TesseractNotFoundError()
      pytesseract.pytesseract.TesseractNotFoundError: tesseract is not installed or it's not in your PATH. See README file for more information.


      我们来分析一下这个错误!错误提示tesseract没有安装,但是我们明明已经执行了pip install pytesseract,那么问题会出在哪里呢?
      我们需要先了解一下pytesseract,它是一款用于光学字符识别(OCR)的python工具,即从图片中识别出和“读取”其中嵌入的文字,底层使用的是[url=]Google[/url]的Tesseract-OCR 引擎,pytesseract只是对Tesseract-OCR的一层封装!看到这里我们就能够理解 ,运行python代码。
      pytesseract.image_to_string() 报错的原因了!因为我的PC上并没有安装Tesseract-OCR,pytesseract是无法调用Tesseract-OCR的api为我们干活的!
      安装Tesseract-OC
      Tesseract-OCR windows 版本的下载链接如下:https://github.com/UB-Mannheim/tesseract/wiki
      下载成功后,只需默认安装,在安装的过程中,如果想对其他国家语言文字识别可以选择相对应的语言包,如下图:

      安装成功后配置路径 C:\Program Files\Tesseract-OCR 到环境变量中即可。
      再次运行,正常执行!大家可以自己做一张文字图片的截图查看效果。
      复杂的登录校验码无法识别
      另外我测试了Tesseract-OCR对复杂校验码的识别情况,如下图:

      结论是:复杂的校验码仍然无法识别。

    分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

  • TA的每日心情
    开心
    9 小时前
  • 签到天数: 503 天

    连续签到: 31 天

    [LV.9]测试副司令

    2#
    发表于 2023-5-27 14:43:02 | 只看该作者
    虽然已经会了,但是还是要感谢
    回复 支持 反对

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /2 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-6-19 14:58 , Processed in 0.063100 second(s), 22 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表