网站首页 > 技术文章 正文
今天我们要学习的是在Python通过调用外部应用识别图片中的文字(OCR)。我们并不需要探究艰深的图像识别的原理和算法,只需要站在巨人的肩膀上知道如何调用百度的文字识别服务就可以用二三十行代码高效实现这个功能了。
首先,我们需要注册百度AI开放平台(ai.baidu.com),点击控制台后找到人工智能中的文字识别创建一个新应用,然后在应用详情里记下我们代码中所需的AppID、API Key、Secret Key。
接下来安装SDK。CMD打开命令提示符,输入pip install baidu-aip即可,如果没有安装pip,会提示命令不存在,已安装可以跳过下面两步。
安装pip包。到pypi.python.org/pypi/pip下载并解包,打开命令提示符窗口,在pip的目录下执行命令:python setup.py install。如果提示“ImportError: No module named setuptools”则说明缺少 “setuptools ”包。
安装setuptools包。到pypi.org/project/setuptools下载并解包,打开命令提示符窗口,在setuptools的目录下执行命令:python setup.py install。
完成以上准备步骤后,开始编程。(图1)

记下我们代码中所需的AppID、API Key、Secret Key
三个常量均为标示用户,为访问百度云做签名验证。AipOcr是百度的Python SDK客户端的功能之一,为我们提供了一系列的识别图片文字的方法。
要调用这一功能非常简单。只需要这一句即可将图片中的文字识别并返回:
result = client.basicGeneral(image);
现在我们通过以下实例代码获得本地图片信息,执行图像识别,结果用print 输出看看。百度识别结果为每行文字一个大括号,再用两行代码整理一下文本格式,程序如图2。

执行程序,最基本的文字识别结果如图3,这个应用流程应该是本地识别图片信息上传至百度云运算返回识别结果,经过测试识别效果优质高效。

识别效果优质高效
当然这仅仅实现了最简单的本地图片文字的基本识别。这个接口还有多项参数可以支持多国语言和各类证照票据二维码等特殊图片的识别。有兴趣的小朋友可以在
https://cloud.baidu.com/doc/OCR/s/Rjwvxzm3n查看接口文档。
这项服务的特殊功能有每天500次的免费使用次数,对于个人学习是完全够用了,如果作为公开应用超量的话还需要付费。
这次我们使用百度提供的服务直接跨进了OCR软件的门槛,在百度AI开放平台上还有语音识别、人脸识别、机器学习、图像识别等众多高大上的功能,直接使用这些人工智能的成果完成自己的应用是不是觉得编程更加有趣了?
# coding=gbk
from aip import AipOcr
# 定义常量
""" 你的 APPID AK SK """
APP_ID = '你的 APPID'
API_KEY = '你的 APP AK'
SECRET_KEY = '你的 APP SK'
# 初始化AipFace对象
client = AipOcr(APP_ID, API_KEY, SECRET_KEY)
# 读取图片
def get_file_content(filePath):
with open(filePath, 'rb') as fp:
return fp.read()
image = get_file_content('本地图片地址')
# 调用通用文字识别, 图片为本地图片
result = client.basicGeneral(image);
print (result)
#将所有的文字都合并到一起
for item in result['words_result']:
print(item['words'])
- 上一篇: 掌握Pymysql轻松实现Python数据库编程
- 下一篇: Python 简单实现贪吃蛇小游戏
猜你喜欢
- 2024-12-24 XML处理神器:Python类库让你轻松实现复杂XML操作和数据修改
- 2024-12-24 使用python实现九九乘法口诀表,使用这个语法,只需一行代码
- 2024-12-24 Python PyInstaller安装和使用教程
- 2024-12-24 pyinstaller,一个超酷的 Python 库!
- 2024-12-24 Python中Pyinstaller库的安装方法(全)
- 2024-12-24 Python音频处理的新选择:深入探索PyAudioMixer库
- 2024-12-24 PyUSB——使用Python链接USB设备
- 2024-12-24 Python+MySQL数据库操作(PyMySQL)
- 2024-12-24 Python 简单实现贪吃蛇小游戏
- 2024-12-24 掌握Pymysql轻松实现Python数据库编程
- 05-25Python 3.14 t-string 要来了,它与 f-string 有何不同?
- 05-25Python基础元素语法总结
- 05-25Python中的变量是什么东西?
- 05-25新手常见的python报错及解决方案
- 05-2511-Python变量
- 05-2510个每个人都是需要知道Python问题
- 05-25Python编程:轻松掌握函数定义、类型及其参数传递方式
- 05-25Python基础语法
- 257℃Python短文,Python中的嵌套条件语句(六)
- 257℃python笔记:for循环嵌套。end=""的作用,图形打印
- 256℃PythonNet:实现Python与.Net代码相互调用!
- 251℃Python操作Sqlserver数据库(多库同时异步执行:增删改查)
- 251℃Python实现字符串小写转大写并写入文件
- 106℃原来2025是完美的平方年,一起探索六种平方的算吧
- 90℃Python 和 JavaScript 终于联姻了!PythonMonkey 要火?
- 81℃Ollama v0.4.5-v0.4.7 更新集合:Ollama Python 库改进、新模型支持
- 最近发表
- 标签列表
-
- python中类 (31)
- python 迭代 (34)
- python 小写 (35)
- python怎么输出 (33)
- python 日志 (35)
- python语音 (31)
- python 工程师 (34)
- python3 安装 (31)
- python音乐 (31)
- 安卓 python (32)
- python 小游戏 (32)
- python 安卓 (31)
- python聚类 (34)
- python向量 (31)
- python大全 (31)
- python次方 (33)
- python桌面 (32)
- python总结 (34)
- python浏览器 (32)
- python 请求 (32)
- python 前端 (32)
- python验证码 (33)
- python 题目 (32)
- python 文件写 (33)
- python中的用法 (32)