一个小需求---实现车牌识别。html
目前有两个想法python
1. 调云在线的接口或者使用SDK作开发(配置环境和编译第三方库很麻烦,固然使用python能够避免这些问题)算法
2. 本身实现车牌识别算法(复杂)json
一开始准备使用百度云文字识别C++ SDK来作,发现须要准备curl、jsoncpp和OpenCV,而且curl和jsoncpp须要本身编译,很麻烦,因此换用了python来作,真的是顺畅简单。curl
python官网下载地址:https://www.python.org/downloads/release/python-374/ 建议直接下载安装版installer(看对系统和位数)编码
打开安装包无脑安装便可。安装好以后,看一下是否安装成功。url
cmdspa
python --version
参考https://cloud.baidu.com/doc/OCR/s/pjwvxzmtc文档,安装python SDK3d
查看pip版本(python环境自带,可是要注意版本)code
pip --version
若是版本不合适,那么自行升级pip
pip install -U pip
安装baidu-aip
pip install baidu-aip
(安装成功的样子)
如今咱们的百度云SDK就安装好了,下来建立应用
登陆百度云(没帐号注册一下)
建立应用
本身填一下
如今咱们就建立好了车牌识别的应用,点击应用列表可查看。
这里的APPID、API KEY、Secret Key要在代码中使用。(注意不要泄漏)
python代码实现
1 ''' 2 Statement 3 1. using the file 4 2. prepare a image path and call func "get_license_plate(filePath)" 5 3. you can get a json object 6 4. get the info from the pbject 7 example : 8 { 9 "log_id": 3583925545, 10 "words_result": { 11 "color": "blue", 12 "number": "苏HS7766" 13 } 14 } 15 ''' 16 17 from aip import AipOcr 18 import json 19 20 """get img""" 21 def get_file_content(filePath): 22 with open(filePath, 'rb') as fp: 23 return fp.read() 24 25 """ get licsense plate """ 26 def get_license_plate(filePath): 27 """ APPID AK SK """ 28 APP_ID = '********' 29 API_KEY = '**************' 30 SECRET_KEY = '******************' 31 32 """ create client """ 33 client = AipOcr(APP_ID, API_KEY, SECRET_KEY) 34 35 image = get_file_content(filePath) 36 37 """ 调用车牌识别 """ 38 res = client.licensePlate(image) 39 return res 40 41 42 """ call example """ 43 str = 'C:\\Users\\***\\Desktop\\big.jpg' """ 照片绝对地址 """ 44 res = get_license_plate(str) 45 print('车牌号码:' + res['words_result']['number']) 46 print('车牌颜色:' + res['words_result']['color'])
代码分解
引入库
from aip import AipOcr """百度云SDK""" import json """json库"""
建立客户端
""" APPID AK SK 本身建立的应用中的数据""" APP_ID = '*******' API_KEY = '***************' SECRET_KEY = '******************' """ create client """ client = AipOcr(APP_ID, API_KEY, SECRET_KEY)
调用接口获得车牌识别结果
image = get_file_content(filePath) """ 调用车牌识别 """ res = client.licensePlate(image)
这里的res是一个json对象/一个dict
例子
{ "log_id": 3583925545, "words_result": { "color": "blue", "number": "苏HS7766" } }
可使用res['listname']['listname']形式获取字典数据
print('车牌号码:' + res['words_result']['number']) print('车牌颜色:' + res['words_result']['color'])
至此,咱们就实现了使用百度云SDK,经过编写python代码调用接口的车牌识别需求。
【1】百度云API文档:https://cloud.baidu.com/doc/OCR/s/pjwvxzmtc/
【2】python pip安装与使用:https://www.runoob.com/w3cnote/python-pip-install-usage.html
【3】python官网:https://www.python.org/downloads/release/python-374/
原文出处:https://www.cnblogs.com/yocichen/p/11621781.html