利用百度 AI 開(kāi)發(fā)平臺(tái)的 OCR 文字識(shí)別 API 識(shí)別并提取圖片中的文字。首先需注冊(cè)獲取 API 調(diào)用的 ID 和 key,步驟如下:
打開(kāi)百度AI開(kāi)放平臺(tái),進(jìn)入控制臺(tái)中的文字識(shí)別應(yīng)用(需要有百度賬號(hào))。
創(chuàng)建一個(gè)應(yīng)用,并進(jìn)入管理應(yīng)用,記下 AppID, API Key, Secrect Key,調(diào)用 API需用到。
最后安裝 python 的百度ai接口的的庫(kù)
以下是代碼實(shí)現(xiàn),需將所有識(shí)別的圖片放進(jìn)名為 picture 的文件夾。
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
"""
Created on Tue Jun 12 09:37:38 2018
利用百度api實(shí)現(xiàn)圖片文本識(shí)別
@author: XnCSD
"""
import glob
from os import path
import os
from aip import AipOcr
from PIL import Image
def convertimg(picfile, outdir):
'''調(diào)整圖片大小,對(duì)于過(guò)大的圖片進(jìn)行壓縮
picfile: 圖片路徑
outdir: 圖片輸出路徑
'''
img = Image.open(picfile)
width, height = img.size
while(width*height > 4000000): # 該數(shù)值壓縮后的圖片大約 兩百多k
width = width // 2
height = height // 2
new_img=img.resize((width, height),Image.BILINEAR)
new_img.save(path.join(outdir,os.path.basename(picfile)))
def baiduOCR(picfile, outfile):
"""利用百度api識(shí)別文本,并保存提取的文字
picfile: 圖片文件名
outfile: 輸出文件
"""
filename = path.basename(picfile)
APP_ID = '******' # 剛才獲取的 ID,下同
API_KEY = '******'
SECRECT_KEY = '******'
client = AipOcr(APP_ID, API_KEY, SECRECT_KEY)
i = open(picfile, 'rb')
img = i.read()
print("正在識(shí)別圖片:\t" + filename)
message = client.basicGeneral(img) # 通用文字識(shí)別,每天 50 000 次免費(fèi)
#message = client.basicAccurate(img) # 通用文字高精度識(shí)別,每天 800 次免費(fèi)
print("識(shí)別成功!")
i.close();
with open(outfile, 'a+') as fo:
fo.writelines("+" * 60 + '\n')
fo.writelines("識(shí)別圖片:\t" + filename + "\n" * 2)
fo.writelines("文本內(nèi)容:\n")
# 輸出文本內(nèi)容
for text in message.get('words_result'):
fo.writelines(text.get('words') + '\n')
fo.writelines('\n'*2)
print("文本導(dǎo)出成功!")
print()
if __name__ == "__main__":
outfile = 'export.txt'
outdir = 'tmp'
if path.exists(outfile):
os.remove(outfile)
if not path.exists(outdir):
os.mkdir(outdir)
print("壓縮過(guò)大的圖片...")
// 首先對(duì)過(guò)大的圖片進(jìn)行壓縮,以提高識(shí)別速度,將壓縮的圖片保存與臨時(shí)文件夾中
for picfile in glob.glob("picture/*"):
convertimg(picfile, outdir)
print("圖片識(shí)別...")
for picfile in glob.glob("tmp/*"):
baiduOCR(picfile, outfile)
os.remove(picfile)
print('圖片文本提取結(jié)束!文本輸出結(jié)果位于 %s 文件中。' % outfile)
os.removedirs(outdir)
到此這篇關(guān)于Python基于百度API識(shí)別并提取圖片中文字的文章就介紹到這了,更多相關(guān)Python百度API識(shí)別圖片文字內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
您可能感興趣的文章:- Python基于百度AI的文字識(shí)別的示例
- python利用百度AI實(shí)現(xiàn)文字識(shí)別功能
- python使用百度文字識(shí)別功能方法詳解
- Python3調(diào)用百度AI識(shí)別圖片中的文字功能示例【測(cè)試可用】
- Python基于百度云文字識(shí)別API
- Python基于百度AI實(shí)現(xiàn)OCR文字識(shí)別
- python 3調(diào)用百度OCR API實(shí)現(xiàn)剪貼板文字識(shí)別
- Python調(diào)用百度OCR實(shí)現(xiàn)圖片文字識(shí)別的示例代碼
- python 利用百度API識(shí)別圖片文字(多線程版)
- Python調(diào)用百度AI實(shí)現(xiàn)圖片上文字識(shí)別功能實(shí)例