失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > python调用百度接口实现ocr识别_Python 3调用百度OCR API实现剪贴板文字识别

python调用百度接口实现ocr识别_Python 3调用百度OCR API实现剪贴板文字识别

时间:2018-12-18 04:14:52

相关推荐

python调用百度接口实现ocr识别_Python 3调用百度OCR API实现剪贴板文字识别

本程序调用百度OCR API对剪贴板的图片文字识别,配合CaptureScreen软件,可快速识别文字。

#!python3

import urllib.request, urllib.parse

import os, io, sys, json, socket

import base64

from PIL import ImageGrab

socket.setdefaulttimeout(30)

def get_auth():

apikey = 'your apikey'

secret_key = 'your secret key'

host = '/oauth/2.0/token?grant_type=client_credentials&client_id=%s&client_secret=%s' % (apikey, secret_key)

req = urllib.request.Request(host)

req.add_header('Content-Type', 'application/json; charset=UTF-8')

res = urllib.request.urlopen(req)

content = res.read()

if (content):

o = json.loads(content.decode())

return o['access_token']

return None

def ocr_clipboard():

im = ImageGrab.grabclipboard()

if im is None:

print('No image in clipboard')

return

print('image size: %sx%s\n>>>\n' % (im.size[0], im.size[1]))

mf = io.BytesIO()

im.save(mf, 'JPEG')

mf.seek(0)

buf = mf.read()

b64 = base64.encodebytes(buf)

access_token = get_auth()

if access_token is not None:

url = '/rest/2.0/ocr/v1/general_basic?access_token=%s' % access_token

data = urllib.parse.urlencode({'image' : b64}).encode()

req = urllib.request.Request(url, method='POST')

req.add_header('Content-Type', 'application/x-www-form-urlencoded')

with urllib.request.urlopen(req, data) as p:

res = p.read().decode('utf-8')

o = json.loads(res)

if o['words_result'] is not None:

for w in o['words_result']:

print(w['words'])

print('\n<<

else:

print('access_token is none')

if __name__ == '__main__':

x = input('ocr form clipboard image: z to ocr, q to quit-->')

while(x != 'q'):

if x=='z':

ocr_clipboard()

x = input('ocr from clipboard image: r to ocr, q to quit-->')

print('bye')

如果觉得《python调用百度接口实现ocr识别_Python 3调用百度OCR API实现剪贴板文字识别》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。