Python OCR 识别图片内容

本文介绍了两种图像文字识别的方法,包括调用百度API进行文字识别及使用EasyOCR库进行识别。详细步骤涵盖安装环境、模型下载及代码实现,适用于Python3环境。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. 调用百度文字识别接口&识别图片内容

百度识别接口申请地址
百度接口页
修改MyPath 路径即可

MyPath = 'E:\\pdf-图片\\'
filesoure = MyPath


def baiduduqu(filesoure, filename):
    from aip import AipOcr
    import re
    import os
    APP_ID = '26646243'
    API_KEY = 'uH8dMfFHRBI0DTr6yzGCoD4X'
    SECRET_KEY = ''
    client = AipOcr(APP_ID, API_KEY, SECRET_KEY)
    dakai = open(filename, 'rb')
    duqu = dakai.read()
    message = client.basicGeneral(duqu)
    result = message.get('words_result')
    if result is not None:
        for duqu in message.get('words_result'):
            print(duqu.get('words'))
            with open("1pdf.txt", encoding='utf-8', mode="a") as f:
                f.write(duqu.get('words') + '\n')


def filename(fielsoure, filetype):
    import os
    pathDir = os.listdir(filesoure)
    for allDir in pathDir:
        child = os.path.join('%s%s' % (filesoure, allDir))
        print(child)
        baiduduqu(filesoure, child)


def run():
    import os
    os.chdir(filesoure)
    for i in os.listdir(os.getcwd()):
        postfix = os.path.splitext(i)[1]
        if postfix == '.jpeg' or postfix == '.png':
            filename(filesoure, postfix)


if __name__ == '__main__':
    run()

2. 使用easyocr库识别

2.1 安装Python 3环境

Python官网

2.2 安装easyocr

pip install -i https://pypi.tuna.tsinghua.edu.cn/simple/ easyocr

2.3 安装模型

网盘链接:

https://pan.baidu.com/s/1xyPsKORak447jS82Pt-JHg 

提取码: onvl
复制到用户目录(python安装路径lib里面搜索) .EasyOCR\model

2.4 安装cv2

pip install -i https://pypi.tuna.tsinghua.edu.cn/simple/ opencv-python

2.5 代码

model_storage_directory 是模型所在本地路径

import easyocr


def run():
    reader = easyocr.Reader(['ch_sim', 'en'], gpu=False, model_storage_directory=r'C:\Users\Work\AppData\Local\Programs'
                                                                                 r'\Python\Python37\Lib\site-packages'
                                                                                 r'\easyocr\model')
    context = ''
    for i in range(53, 1507):
        print('#' * 200 + ' 第{}页'.format(i))
        path = r'E:\pdfImage-1\{}.png'.format(i)
        result = reader.readtext(path)
        print('#' * 200 + '长度:{}'.format(len(result)))
        for j in range(5, len(result)):
            print(result[j][1])


if __name__ == '__main__':
    run()

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

李同学va

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值