AnyEvent 的使用

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/&#160;//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;
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

推薦閱讀更多精彩內(nèi)容

  • 草鞠又一次被強迫待在山洞里,那個山洞連大人也會懼怕,路過此處都會繞道而行。 草鞠不知道被迫關(guān)在里面多少次了。次數(shù)越...
    成燦_吶閱讀 687評論 0 7
  • 1,選擇目標(biāo),做足準(zhǔn)備 要做的事情很多,想學(xué)的技能也很多,但是一天只有24小時,秉承昨天說的文章,最重要的事只有一...
    思思_21cc閱讀 210評論 0 1
  • 鮮城致力于為本地同城生活的網(wǎng)友們推薦更多的周末休息娛樂活動,本地特色美食、同城娛樂、家庭親子、時尚購物、演出活動等...
    piegroups閱讀 380評論 0 0
  • -01- 我 一個剛剛踏入職場,思維活躍,時而文藝,時而孩子,時而漢子的雙子座程序媛,并且一直處于迷茫和奮斗中。 ...
    夢里星閱讀 583評論 0 6
  • 法國科學(xué)家笛卡爾有句名言“越學(xué)習(xí),越發(fā)現(xiàn)自己的無知。 ”這幾年由于工作上的角色不斷變更,讓我對這句話有了越...
    綠蘿0527閱讀 368評論 2 2