电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

如何基于Python代碼實現高精度免費OCR工具

瀏覽:55日期:2022-07-20 15:49:03

近期Github開源了一款基于Python開發、名為Textshot的截圖工具,剛開源不到半個月已經500+Star。

這兩天抽空看了一下Textshot的源碼,的確是一個值得介紹的項目。

相對于大多數OCR工具復雜工程、差強人意的效果,Textshot具有明顯的優勢,

項目簡單 技術點豐富

項目簡單

Textshot整個項目只有1個Python文件、139行代碼,沒有復雜的第三方庫應用,也不涉及過多后端算法的調用。

技術點豐富

Textshot這個項目雖然只有短短的139行代碼,但是,卻涉及Python中多個方面的知識應用,

UI開發 截圖工具開發 后端引擎調用

通過這短短的項目,你不僅可以了解如何利用PyQt5實現一個用戶界面,還可以學會如何使用pyscreenshot開發一款自己的截圖工具。此外,還能夠學會后端tesseract的調用。

換句話說,這短短的139行代碼囊括了前端至后端的整個流程,而且涉及到截圖和OCR兩款工具的銜接。因此,Textshot雖然工程不大,卻是一個非常完備、值得學習的項目。

本文就來剖析這個項目的源代碼,教你一步一步實現自用且永久免費的截圖&OCR工具!

tesseract

目前OCR工具數不勝數,但是大多數都是在相同的后端算法上面進行了不同的封裝而已。而真正在OCR核心做的較好、值得大書特書的,那么一定非tesseract莫屬

tesseract早在1985就已經開始由HP實驗室開始研發,而在1995年更是被評為最為準確的3款OCR工具之一。此后,tesseract被開源,經過Google對其不斷的進行優化和升級,它目前已經成為OCR方面一款標桿性的工具。很多開源或者付費的OCR工具,都是直接調用tesseract或者對其進行稍許優化。

而今天介紹的Textshot就是直接調用tesseract后端引擎進行OCR識別。因此,Textshot只是實現了一款截圖工具,起到前后端的串聯作用,在OCR識別算法方面并沒有做任何工作。

tesseract安裝

由于Textshot的OCR識別需要調用tesseract后端引擎,所以,首先需要安裝tesseract。

Windows版安裝可以直接訪問下載鏈接[1].

Mac下可以使用Homebrew進行安裝,

brew install tesseract 

Textshot

Textshot是一款截圖識別文字的OCR工具,因此,它主要涉及2個環境,

截圖

OCR識別

Textshot首先通過截圖獲取需要進行文字識別的圖像,然后對這副圖像進行OCR文字識別,輸出識別結果。

前面已經介紹了,Textshot的OCR識別階段調用的是tesseract,所以只需要1行代碼即可完成。

因此,Textshot的工作主要是圍繞前端窗口和截圖工具的實現方面。

截圖工具

截圖工具是我們經常會用到的一種工具,如何實現一款截圖工具?

很多人會把它想的非常復雜,其實,Python中有很多可以實現截圖的庫或者函數,例如,pyscreenshot或者pillow中的ImageGrab函數,它的調用方式如下,

shot = ImageGrab.grab(bbox=(x1, y1, x2, y2))

也就是說,我們只需要把鼠標框選的起點和終點坐標傳給grab方法就可以實現截圖功能。

那么,現在問題就轉化為如何獲取鼠標框選的起點和終點?

Textshot通過調用PyQt5并繼承QWidget來實現鼠標框選過程中的一些方法來獲取框選的起點和終點。

Textshot繼承和重寫QWidget方法主要包括如下幾個,

keyPressEvent(self, event):鍵盤響應函數 paintEvent(self, event):UI繪制函數 mousePressEvent(self, event):鼠標點擊事件 mouseMoveEvent(self, event):鼠標移動事件 mouseReleaseEvent(self, event):鼠標釋放事件

可以看出,上面重寫的方法以及囊括了截圖過程中涉及的各個動作,

點擊鼠標 拖動、繪制截圖框 釋放鼠標

class Snipper(QtWidgets.QWidget): def __init__(self, parent=None, flags=Qt.WindowFlags()): super().__init__(parent=parent, flags=flags) self.setWindowTitle('TextShot') self.setWindowFlags( Qt.FramelessWindowHint | Qt.WindowStaysOnTopHint | Qt.Dialog ) self.is_macos = sys.platform.startswith('darwin') if self.is_macos: self.setWindowState(self.windowState() | Qt.WindowMaximized) else: self.setWindowState(self.windowState() | Qt.WindowFullScreen) self.setStyleSheet('background-color: black') self.setWindowOpacity(0.5) QtWidgets.QApplication.setOverrideCursor(QtGui.QCursor(QtCore.Qt.CrossCursor)) self.start, self.end = QtCore.QPoint(), QtCore.QPoint() def keyPressEvent(self, event): if event.key() == Qt.Key_Escape: QtWidgets.QApplication.quit() return super().keyPressEvent(event) def paintEvent(self, event): if self.start == self.end: return super().paintEvent(event) painter = QtGui.QPainter(self) painter.setPen(QtGui.QPen(QtGui.QColor(255, 255, 255), 3)) painter.setBrush(QtGui.QColor(255, 255, 255, 100)) if self.is_macos: start, end = (self.mapFromGlobal(self.start), self.mapFromGlobal(self.end)) else: start, end = self.start, self.end painter.drawRect(QtCore.QRect(start, end)) return super().paintEvent(event) def mousePressEvent(self, event): self.start = self.end = QtGui.QCursor.pos() self.update() return super().mousePressEvent(event) def mouseMoveEvent(self, event): self.end = QtGui.QCursor.pos() self.update() return super().mousePressEvent(event) def mouseReleaseEvent(self, event): if self.start == self.end: return super().mouseReleaseEvent(event) x1, x2 = sorted((self.start.x(), self.end.x())) y1, y2 = sorted((self.start.y(), self.end.y()))

然后啟動截圖界面,

QtCore.QCoreApplication.setAttribute(Qt.AA_DisableHighDpiScaling)app = QtWidgets.QApplication(sys.argv)window = QtWidgets.QMainWindow()snipper = Snipper(window)snipper.show()

用戶拖動、框選窗口,會獲取窗口的起點和終點的坐標,這時候可以調用下面語句進行截圖,獲取需要OCR識別的文本圖像,

shot = ImageGrab.grab(bbox=(x1, y1, x2, y2))

OCR文字識別

通過ImageGrab.grab截取到文本圖像shot,下一步就是要把圖像內容輸入給后端的tesseract引擎,讓它把圖像轉化為字符串

result = pytesseract.image_to_string(img, timeout=2, lang=(sys.argv[1] if len(sys.argv) > 1 else None))

到這里,就實現了一款準確度高、永久免費的OCR工具。

回顧一下Textshot的項目,我們會發現截圖坐標范圍內的圖像、OCR識別只需要2行代碼,大多數都是在圍繞獲取窗口起點和終點坐標在開發。換句話說,Textshot這個項目對OCR核心部分并沒有做任何更改,只是在產品包裝方面做了一些巧妙的工作。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 污水处理设备,一体化泵站,一体化净水设备-「梦之洁环保设备厂家」 | 振动传感器,检波器-威海广达勘探仪器有限公司 | 南京交通事故律师-专打交通事故的南京律师| 聚氨酯复合板保温板厂家_廊坊华宇创新科技有限公司 | PC构件-PC预制构件-构件设计-建筑预制构件-PC构件厂-锦萧新材料科技(浙江)股份有限公司 | 西门子伺服控制器维修-伺服驱动放大器-828D数控机床维修-上海涌迪 | 船老大板材_浙江船老大全屋定制_船老大官网 | 氧化锆纤维_1800度高温退火炉_1800度高温烧结炉-南京理工宇龙新材料股份有限公司 | 智能案卷柜_卷宗柜_钥匙柜_文件流转柜_装备柜_浙江福源智能科技有限公司 | 超声波成孔成槽质量检测仪-压浆机-桥梁预应力智能张拉设备-上海硕冠检测设备有限公司 | 电池高低温试验箱-气态冲击箱-双层电池防爆箱|简户百科 | 上海新光明泵业制造有限公司-电动隔膜泵,气动隔膜泵,卧式|立式离心泵厂家 | 暴风影音 | 气密性检测仪_气密性检测设备_防水测试仪_密封测试仪-岳信仪器 | 吸音板,隔音板,吸音材料,吸音板价格,声学材料 - 佛山诺声吸音板厂家 | 北京易通慧公司从事北京网站优化,北京网络推广、网站建设一站式服务商-北京网站优化公司 | 上海防爆真空干燥箱-上海防爆冷库-上海防爆冷柜?-上海浦下防爆设备厂家? | ◆大型吹塑加工|吹塑加工|吹塑代加工|吹塑加工厂|吹塑设备|滚塑加工|滚塑代加工-莱力奇塑业有限公司 | 商标转让-商标注册-商标查询-软著专利服务平台 - 赣江万网 | 凝胶成像仪,化学发光凝胶成像系统,凝胶成像分析系统-上海培清科技有限公司 | 杭州营业执照代办-公司变更价格-许可证办理流程_杭州福道财务管理咨询有限公司 | 船用泵,船用离心泵,船用喷射泵,泰州隆华船舶设备有限公司 | 无线讲解器-导游讲解器-自助讲解器-分区讲解系统 品牌生产厂家[鹰米讲解-合肥市徽马信息科技有限公司] | EDLC超级法拉电容器_LIC锂离子超级电容_超级电容模组_软包单体电容电池_轴向薄膜电力电容器_深圳佳名兴电容有限公司_JMX专注中高端品牌电容生产厂家 | 不锈钢发酵罐_水果酒发酵罐_谷物发酵罐_山东誉诚不锈钢制品有限公司 | 蓄电池回收,ups电池后备电源回收,铅酸蓄电池回收,机房电源回收-广州益夫铅酸电池回收公司 | 单级/双级旋片式真空泵厂家,2xz旋片真空泵-浙江台州求精真空泵有限公司 | 作文导航网_作文之家_满分作文_优秀作文_作文大全_作文素材_最新作文分享发布平台 | 校车_校车价格_19座幼儿园校车_幼儿园校车_大鼻子校车 | 湖南专升本-湖南省专升本报名-湖南统招专升本考试网 | 马尔表面粗糙度仪-MAHR-T500Hommel-Mitutoyo粗糙度仪-笃挚仪器 | 派克防爆伺服电机品牌|国产防爆伺服电机|高低温伺服电机|杭州摩森机电科技有限公司 | 「安徽双凯」自动售货机-无人售货机-成人用品-自动饮料食品零食售货机 | 【黄页88网】-B2B电子商务平台,b2b平台免费发布信息网 | 搪玻璃冷凝器_厂家-越宏化工设备| 心肺复苏模拟人|医学模型|急救护理模型|医学教学模型上海康人医学仪器设备有限公司 | 净水器代理,净水器招商,净水器加盟-FineSky德国法兹全屋净水 | 流量卡中心-流量卡套餐查询系统_移动电信联通流量卡套餐大全 | 谷梁科技| 西安中国国际旅行社(西安国旅) | AGV无人叉车_激光叉车AGV_仓储AGV小车_AGV无人搬运车-南昌IKV机器人有限公司[官网] |