use strict;
use warnings;
use 5.010;
use Mojo::UserAgent;
use Mojo::UserAgent::CookieJar;
use Mojo::UserAgent::Proxy;
use Win32::API;
use MyExcelFormatter;
use Encode;
use AnyEvent;
use Excel::Writer::XLSX;
sub H{
my $text = shift;
return decode('utf8',$text); # 進行轉(zhuǎn)碼
}
sub getTime
{
my $time = shift || time();
my ($sec,$min,$hour,$mday,$mon,$year,$wday,$yday,$isdst) = localtime($time);
$year += 1900;
$mon ++;
$min = '0'.$min if length($min) < 2;
$sec = '0'.$sec if length($sec) < 2;
$mon = '0'.$mon if length($mon) < 2;
$mday = '0'.$mday if length($mday) < 2;
$hour = '0'.$hour if length($hour) < 2;
my $weekday = ('Sun','Mon','Tue','Wed','Thu','Fri','Sat')[$wday];
return { 'second' => $sec,
'minute' => $min,
'hour' => $hour,
'day' => $mday,
'month' => $mon,
'year' => $year,
'weekNo' => $wday,
'wday' => $weekday,
'yday' => $yday,
'date' => "$year-$mon-$mday"
};
}
my $cv = AnyEvent->condvar;
my $count = 0;
my $w; $w = AnyEvent->timer(
after => 1,
interval => 300, # 每隔 5 分鐘檢查一次
cb => sub {
my $date = getTime();
my $today = $date->{date}; # 獲取xxxx-xx-xx這樣的日期
my $hour = $date->{hour};
my $minute =$date->{minute};
#my $month = $date->{month}; # 獲取月
#my $day = $date->{day}; # 獲取日
#my $year = $date->{year}; # 獲取年
#my $weekday = $date->{wday}; # 獲取星期
my $yesterday = getTime(time() - 86400)->{date}; # 獲取昨天的日期,也可以用 86400*N,獲取N天前的日期
$count++;
say " -> check the $count times at $hour:$minute";
my $ua = Mojo::UserAgent->new(timeout => 600);
my $response = $ua->get('http://118.144.74.39:9198/commons/image.jsp');
my $login_url = 'http://118.144.74.39:9198/login.do';
my $post_url='http://118.144.74.39:9198/report/listReport.do';
if ($response->success) {
# $response->res->content->asset->move_to('verifycode.BMP');
# my $dll={};
# my $D='AdvOcr.dll';
# $dll->{OcrInit} = Win32::API->new($D, 'OcrInit',[],'N') || die " Can't open the dll file $D $!";
# $dll->{OCR_C} = Win32::API->new($D, 'OCR_C',['P','P'],'P');
# if($dll->{OcrInit}->Call()){
# my $ocr_txt=$dll->{OCR_C}->Call('163_esales','verifycode.BMP');
# print " -> 驗證碼:$ocr_txt\n";
$response->res->content->asset->move_to('verifycode.BMP');
system("tesseract.exe verifycode.BMP verify 1>nul 2>nul");
open my $verify,"<","verify.txt" or die;
chomp(my $verifycode = <$verify>);
close $verify;
my $login_form= {
'anchor' => '#/navigation/109/menugroup/blank/menu/dmsProdMappingListNe',
'rand' => "$verifycode",
'userAccount' => 'winc_sxw',
'userPassword' => '000000',
};
my $tx = $ua->post( $login_url => form => $login_form );
if ( $tx->success ) {
if ($tx->res->body !~ /驗證碼輸入錯誤/) {
my $post_form={
'_RES_ID_' => '254',
'activeStoreSource' => 'OT',
'colIds' => '18,0,1,2,3,5,6,7,21,35,32,33,29,30,31,8,22,27,28,9,10,11,12,13,25,26,14,15,16,17,20,24,34,23,19',
# 'colIds' => '0,1,2,3,5,7,8,9,12,15,26',
'createTime1' => "$today",
'createTime2' => "$today",
'ec_i' => 'server_dmsProdMappingListNew',
'isValid' => '2',
'mappingState' => '0',
'noMap' => '0',
'reportName' => 'server/dmsProdMappingListNew',
'server_dmsProdMappingListNew_crd' => '99999',
'server_dmsProdMappingListNew_p' => '1',
'server_dmsProdMappingListNew_rd' => '99999',
'totalstatus' => '2',
};
my $tx=$ua->post($post_url => form => $post_form );
if (encode("gb2312",H($tx->res->body)) =~/區(qū)/){
my @items=encode("gb2312",H($tx->res->body)) =~ m/區(qū)/g;
say " -> 中區(qū)有 ",scalar @items," 條記錄";
# 直接從網(wǎng)頁中生成 xlsx 文件
my $workbook = Excel::Writer::XLSX->new( "產(chǎn)品匹配維護.xlsx" );
my $new_worksheet = $workbook->add_worksheet('PV');
my @columns;
my $collection = $tx->res->dom->find('tbody > tr'); # 取得所有列,每個 tr 是一列
# say $collection;
foreach my $ele (@$collection) {
my $td = $ele->find('td')->text; # 每一行中的所有元素
$td =~s/ //g;
# say encode("gb2312",$td);
push @columns,[@$td] if encode("gb2312",$td) =~/中區(qū)/;
# <>;
}
my $count= scalar @columns;
$new_worksheet->keep_leading_zeros(); # 保留前導(dǎo)0
$new_worksheet->write_col( 'A1', \@columns);
say " -> download $count rows";
exit;
} else {
say " -> [ OK NOW ]";
say " ---------------";
}
}
}
}
}
);
$cv->recv;
AnyEvent 的使用
最后編輯于 :
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
推薦閱讀更多精彩內(nèi)容
- 1,選擇目標(biāo),做足準(zhǔn)備 要做的事情很多,想學(xué)的技能也很多,但是一天只有24小時,秉承昨天說的文章,最重要的事只有一...