<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
大家好,我是J哥。
也許你還記得,前不久復旦大學一博士生寫了130行Python
程式碼,批次識別核酸截圖內容的故事。當時還被人民日報公眾號報道出來,誇讚用所學貢獻青春力量!
其實,批次文字識別(OCR)是Python
辦公自動化的基本操作,應用在我們工作生活中的方方面面,比如車牌識別、證件識別、銀行卡識別、票據識別等等。
Python
中OCR
第三方庫非常多,比如easyocr
、PaddleOCR
、cnocr
等等。當然,直接呼叫百度API
也是可以的,不過超過一定限額後要收費,因此本文主要以開源免費的easyocr
來進行介紹。
本文以證件識別為例,我網上找了3張虛擬身份證來實驗:
運用easyocr
進行識別並儲存為Excel
,效果如下:
在Python
中使用 easyocr
非常簡單,只要使用pip
命令安裝easyocr
即可(建議使用清華源,否則安裝會比較慢)。
pip install easyocr
不過 easyocr
的深度學習演演算法依賴於另一個著名的第三方模組 pytorch
,圖形處理部分則會用到 opencv
、Pillow
等,所以還需要確保自己電腦上已經安裝這些基礎模組。
1.easyocr
識別圖片程式碼非常簡潔,只需要建立一個easyocr.Reader
類物件,指定以下兩個常用引數:
2.呼叫Reader
物件的readtext
方法,將圖片中所有文字讀入一個列表並返回。
''' 公眾號:菜J學Python 作者:J哥 ''' # 匯入模組 import easyocr # 圖片路徑 image = './id_card/1.jpg' # 建立ocr的reader物件,識別中英文 ocr = easyocr.Reader(['ch_sim', 'en'],gpu=False) # 識別圖片文字 content = ocr.readtext(image) print(content)
識別結果如下:
[([[39, 31], [207, 31], [207, 67], [39, 67]], '姓 名 韋小寶', 0.8973890994570185), ([[40, 82], [159, 82], [159, 119], [40, 119]], '性 別 男', 0.9799311480828728), ([[178, 86], [272, 86], [272, 116], [178, 116]], '民 族漢', 0.5456928014755249), ([[40, 131], [100, 131], [100, 161], [40, 161]], '出 生', 0.5362269878387451), ([[114, 134], [240, 134], [240, 162], [114, 162]], '1654 年12', 0.6952526392609933), ([[266, 134], [322, 134], [322, 162], [266, 162]], '20日', 0.31329770168285426), ([[42, 181], [395, 181], [395, 213], [42, 213]], '住 址 北京市東城區景山前街4號', 0.48138251996753667), ([[112, 222], [256, 222], [256, 254], [112, 254]], '紫禁城敬事房', 0.9732440311960702), ([[44, 307], [195, 307], [195, 337], [44, 337]], '公民身份證號碼', 0.612808391503521), ([[212, 308], [526, 308], [526, 334], [212, 334]], '112044165412202438', 0.7003081027071493)]
readtext
返回的列表中,每個元素都是一個元組,內含三個資訊:位置、文字、置信度。我們可以在呼叫readtext
時指定一個引數 detail=0
,從而只返回文字內容。於是修改後程式碼和效果如下:
import easyocr image = './id_card/1.jpg' ocr = easyocr.Reader(['ch_sim', 'en'],gpu=False) content = ocr.readtext(image,detail=0) print(content)
['姓 名 韋小寶', '性 別 男', '民 族漢', '出 生', '1654 年12', '20日', '住 址 北京市東城區景山前街4號', '紫禁城敬事房', '公民身份證號碼', '112044165412202438']
批次識別圖片無非就是遍歷圖片資料夾,這裡用到了os.listdir()
方法以返回檔案列表。然後用ocr.readtext()
去識別每一張圖片文字內容,接著通過字串切片來獲取姓名、性別、民族、出生、住址和身份證號等關鍵資訊,最後統一將這些資訊存入列表data
中。
''' 公眾號:菜J學Python 作者:J哥 ''' import easyocr import os # 指明所有圖片所在的資料夾 images = './id_card' # 建立ocr的reader物件,識別中英文 ocr = easyocr.Reader(['ch_sim', 'en']) # 識別圖片文字 content = ocr.readtext(images,detail=0) # 遍歷所有圖片並識別文字,切片提取有效資訊 data = [] for image in os.listdir(images): content = ocr.readtext(f'{images}/{image}', detail=0) print(f"正在識別:{image}") name = content[0][4:] gender = content[1][-1] nation = content[2][-1] birth = content[-5] if "月" not in birth: birth = content[-6] + "月" + content[-5] if "日" not in birth: birth = birth[:-1] + "日" address = content[-4][4:] + content[-3] number = content[-1] print(f"完成識別:{image}") print("-" * 50) data.append([name, gender, nation, birth, address, number])
圖片文字識別之後,建議通過pandas
輸出為Excel
,方便簡潔。
''' 公眾號:菜J學Python 作者:J哥 ''' import pandas as pd # 儲存識別結果至Excel df = pd.DataFrame(data, columns=["姓名", "性別", "民族", "出生", "住址", "身份證號"]) print(f"識別結果如下:") print(df) df.to_excel("識別結果.xlsx", index=False)
到此這篇關於Python實現批次識別圖片文字並存為Excel的文章就介紹到這了,更多相關Python識別圖片文字內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45