麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > Perl > 正文

Perl使用Tesseract-OCR實(shí)現(xiàn)驗(yàn)證碼識(shí)別的方法

2020-02-23 19:45:35
字體:
供稿:網(wǎng)友

我們?cè)陂_發(fā)程序的時(shí)候?qū)τ谝恍?yàn)證碼的識(shí)別比較復(fù)雜,本文是武林技術(shù)頻道小編為大家介紹的Perl使用Tesseract-OCR實(shí)現(xiàn)驗(yàn)證碼識(shí)別的方法,希望對(duì)你學(xué)習(xí)有幫助!

一、Tesseract-OCR 是什么

An OCR Engine that was developed at HP Labs between 1985 and 1995… and now at Google
基于Leptonica(http://leptonica.com/)圖形處理庫開的開源圖形識(shí)別引擎。
支持Linux、Windows、Mac平臺(tái),
支持.NET、C++、Python、Java等開發(fā)語言:https://code.google.com/p/tesseract-ocr/wiki/AddOns
項(xiàng)目地址:https://code.google.com/p/tesseract-ocr/

二、使用方法

下載安裝:https://tesseract-ocr.googlecode.com/files/tesseract-ocr-setup-3.02.02.exe
注意安裝時(shí)的Path目錄、數(shù)學(xué)符號(hào)、語言選項(xiàng),按需選擇。
執(zhí)行:”tesseract yourpic.png res”
圖片 yourpic.png 里面的內(nèi)容會(huì)被識(shí)別后保存在 res.txt
為了更精確的識(shí)別可以去到項(xiàng)目地址上下載相應(yīng)的各種語言的 language tessdata
例如:
簡體中文 https://tesseract-ocr.googlecode.com/files/tesseract-ocr-3.02.chi_sim.tar.gz
繁體中文
下載解壓后 chi_sim.traineddata 復(fù)制到 Tesseract-OCR/tessdata 即可
執(zhí)行:
“tesseract yourpic.png eng” 使用 默認(rèn)eng語言包
“tesseract yourpic.png sim -l chi_sim” 使用 chi_sim語言包
“tesseract yourpic.png tra -l chi_tra” 使用 chi_sim語言包
選擇最接近真實(shí)數(shù)據(jù)的,方便以后修正

三、進(jìn)階使用 Training

為數(shù)不多的training tesseract-ocr中文文檔
http://yy-programer.blogspot.tw/2012/08/training-tesseract-ocr-301.html
對(duì)于高精度需求的需要研究一下了,日常民用級(jí)別,默認(rèn)識(shí)別加后期修正即可。

四、應(yīng)用實(shí)例之吸附代理

針對(duì) http://www.proxyfire.net/ 幾個(gè)代理列表頁的代理吸附

話不多說直接上代碼,
pf.bat

?

pf.pl http://www.proxyfire.net/index.php?pageid=eliteproxylist?????? elite.txt
pf.pl http://www.proxyfire.net/index.php?pageid=anonymousproxylist?? anony.txt
pf.pl http://www.proxyfire.net/index.php?pageid=transparentproxylist trans.txt
pf.pl http://www.proxyfire.net/index.php?pageid=socks4proxylist????? s4.txt
pf.pl http://www.proxyfire.net/index.php?pageid=socks5proxylist????? s5.txt
type *.txt > all.tmp
del *.txt /s/q
ren all.tmp all.txt
@pause


pf.pl

?

?

?


use strict;
?
our $url??? = $ARGV[0];
our $file?? = $ARGV[1];
?
my $res = undef;
my @tmp = undef;
my @pxy = undef;
?
??? `wget $url -q -O ___html`;
??? open FH, "<___html";
??? @tmp = ;
??? close FH;
??? $res = join('',@tmp);
??? undef(@tmp);
??? `del ___html /s /q`;
?
@tmp = ( $res =~ /<img alt="" src="([^" border="0">]+)><//td>(/d+)'http://www.proxyfire.net'.$tmp[$i], 'port'=>$tmp[$i+1]};
??? $i = $i + 1;
}
?
for (my $i=0; $i < @pxy; $i++) {???? if( length(${$pxy[$i]}{ip})>0 )
??? {
??????? `echo off & wget ${$pxy[$i]}{ip} -q -O ___png`;
??????? `tesseract ___png ___ -l chi_tra`;
?
??????? my $txt = undef;??
??????? open FH,"<___.txt";
??????? $txt = ;
??????? close FH;
??????? if ( length($txt)>11 )
??????? {
??????????? $txt =~ s//s+//g;
??????????? $txt =~ s/日/8/g;
??????????? $txt =~ s/昍/88/g;
??????????? $txt =~ s/s0/60/g;
??????????? $txt =~ s/s1/61/g;
??????????? $txt =~ s/s2/62/g;
??????????? $txt =~ s/s3/69/g;
??????????? $txt =~ s/s4/64/g;
??????????? $txt =~ s/s5/65/g;
??????????? $txt =~ s/s7/67/g;
??????????? $txt =~ s/s8/68/g;
??????????? $txt =~ s/s9/69/g;
??????????? $txt =~ s/0s/06/g;
??????????? $txt =~ s/1s/16/g;
??????????? $txt =~ s/2s/26/g;
??????????? $txt =~ s/3s/96/g;
??????????? $txt =~ s/4s/46/g;
??????????? $txt =~ s/5s/56/g;
??????????? $txt =~ s/6s/66/g;
??????????? $txt =~ s/7s/76/g;
??????????? $txt =~ s/8s/86/g;
??????????? $txt =~ s/9s/96/g;
??????????? $txt =~ s/ss/66/g;
??????????? $txt =~ s//.s//.6/g;
??????????? ${$pxy[$i]}{ip} = $txt;
?
??????????? my $bak1 = $txt;
??????????? my $bak2 = $txt;
??????????? $bak1 =~ s/13/19/g;
??????????? $bak1 =~ s//.32/.//.92/./g;
??????????? $bak1 =~ s//.33/.//.99/./g;
?
??????????? $bak2 =~ s/19/13/g;
??????????? $bak2 =~ s//.243//.249/g;
??????????? $bak2 =~ s/203/./209/./g;
?
??????????? open FHX,">>$file";
??????????? print FHX ${$pxy[$i]}{ip}.":".${$pxy[$i]}{port}."/n";
??????????? print FHX $bak1.":".${$pxy[$i]}{port}."/n";
??????????? print FHX $bak2.":".${$pxy[$i]}{port}."/n";
??????????? close FHX;
?
??????? }
??????? my $txt = undef;
??? }
}
`del ___* /s /q`;
undef($url);
undef($file);
undef($res);
undef(@tmp);
undef(@pxy);

Perl使用Tesseract-OCR實(shí)現(xiàn)驗(yàn)證碼識(shí)別的方法大家都了解了嗎?在上文中,武林技術(shù)頻道小編為大家做了簡單的介紹。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 国产美女的小嫩bbb图片 | lutube成人福利在线观看 | 国产精品免费一区二区三区都可以 | 中文字幕亚洲欧美 | 一区二区三区小视频 | 成人在线视频在线观看 | 看全色黄大色黄大片女图片 | 免费放黄网站在线播放 | 国产午夜免费福利 | 免费黄网站在线播放 | 亚洲综合精品 | 国产一级91 | 国产精品国产三级国产在线观看 | 逼特逼视频在线观看 | 日韩黄网站 | 久久久久久久久久综合 | www.99热视频 | a级毛片免费观看在线播放 日本aaa一级片 | 法国性经典xxxhd | 久草视频福利在线观看 | 成人免费在线视频 | 大胆在线日本aⅴ免费视频 美国黄色毛片女人性生活片 | 日韩中字在线 | 毛片免费视频观看 | 免费一级a毛片免费观看 | 草操影院 | 一级黄色影院 | 久久精品视频在线看99 | 久久久久久久久久综合 | 日本在线精品视频 | 香蕉久久久久久 | 久久国语对白 | 日本欧美一区 | 91精品动漫在线观看 | 在线成人免费观看视频 | 黄色成年在线观看 | 国产无限资源在线观看 | 欧产日产国产精品v | 色999国产| www.91pron| 国产精品视频一区二区三区综合 |