主頁 > 知識庫 > Python基于百度API識別并提取圖片中文字

Python基于百度API識別并提取圖片中文字

熱門標(biāo)簽:如何地圖標(biāo)注公司 外賣地址有什么地圖標(biāo)注 預(yù)覽式外呼系統(tǒng) 銀川電話機(jī)器人電話 煙臺電話外呼營銷系統(tǒng) 企業(yè)彩鈴地圖標(biāo)注 電銷機(jī)器人錄音要學(xué)習(xí)什么 長春極信防封電銷卡批發(fā) 上海正規(guī)的外呼系統(tǒng)最新報價

利用百度 AI 開發(fā)平臺的 OCR 文字識別 API 識別并提取圖片中的文字。首先需注冊獲取 API 調(diào)用的 ID 和 key,步驟如下:

打開百度AI開放平臺,進(jìn)入控制臺中的文字識別應(yīng)用(需要有百度賬號)。

創(chuàng)建一個應(yīng)用,并進(jìn)入管理應(yīng)用,記下 AppID, API Key, Secrect Key,調(diào)用 API需用到。



最后安裝 python 的百度ai接口的的庫

pip install baidu-aip

以下是代碼實(shí)現(xiàn),需將所有識別的圖片放進(jìn)名為 picture 的文件夾。

#!/usr/bin/env python3
# -*- coding: utf-8 -*-
"""
Created on Tue Jun 12 09:37:38 2018
利用百度api實(shí)現(xiàn)圖片文本識別
@author: XnCSD
"""

import glob
from os import path
import os
from aip import AipOcr
from PIL import Image

def convertimg(picfile, outdir):
    '''調(diào)整圖片大小,對于過大的圖片進(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識別文本,并保存提取的文字
    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("正在識別圖片:\t" + filename)
    message = client.basicGeneral(img)   # 通用文字識別,每天 50 000 次免費(fèi)
    #message = client.basicAccurate(img)   # 通用文字高精度識別,每天 800 次免費(fèi)
    print("識別成功!")
    i.close();
    
    with open(outfile, 'a+') as fo:
        fo.writelines("+" * 60 + '\n')
        fo.writelines("識別圖片:\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("壓縮過大的圖片...")
    // 首先對過大的圖片進(jìn)行壓縮,以提高識別速度,將壓縮的圖片保存與臨時文件夾中
    for picfile in glob.glob("picture/*"):
        convertimg(picfile, outdir)
    print("圖片識別...")
    for picfile in glob.glob("tmp/*"):
        baiduOCR(picfile, outfile)
        os.remove(picfile)
    print('圖片文本提取結(jié)束!文本輸出結(jié)果位于 %s 文件中。' % outfile)
    os.removedirs(outdir)

到此這篇關(guān)于Python基于百度API識別并提取圖片中文字的文章就介紹到這了,更多相關(guān)Python百度API識別圖片文字內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Python基于百度AI的文字識別的示例
  • python利用百度AI實(shí)現(xiàn)文字識別功能
  • python使用百度文字識別功能方法詳解
  • Python3調(diào)用百度AI識別圖片中的文字功能示例【測試可用】
  • Python基于百度云文字識別API
  • Python基于百度AI實(shí)現(xiàn)OCR文字識別
  • python 3調(diào)用百度OCR API實(shí)現(xiàn)剪貼板文字識別
  • Python調(diào)用百度OCR實(shí)現(xiàn)圖片文字識別的示例代碼
  • python 利用百度API識別圖片文字(多線程版)
  • Python調(diào)用百度AI實(shí)現(xiàn)圖片上文字識別功能實(shí)例

標(biāo)簽:上饒 湖北 宜昌 珠海 潮州 盤錦 西寧 佳木斯

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Python基于百度API識別并提取圖片中文字》,本文關(guān)鍵詞  Python,基于,百度,API,識別,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Python基于百度API識別并提取圖片中文字》相關(guān)的同類信息!
  • 本頁收集關(guān)于Python基于百度API識別并提取圖片中文字的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章