天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

基于curl數據采集之正則處理函數get_matches的使用

根據前兩篇的博文:

基于curl數據采集之單頁面采集函數get_html的使用

基于curl數據采集之單頁面并行采集函數get_htmls的使用

已經可以得到了我們需要的html文件,現在需要處理得到的文件獲取到我們需要的采集的數據。

對于html文檔的解析,沒有像XML那樣的解析類,因為HTML文檔有很多不成對的標簽,很不嚴格。這個時候就需要采用其他的一些輔助類了,simplehtmldom是一個類似于JQuery方式操作HTML文檔的解析類。可以很方便的得到想要的數據,可惜速度慢。這里不是我們這里討論的重點,我主要使用正則來匹配我所需要的采集的數據,可以很快速的得到我需要采集的信息。

考慮到get_html可以判斷返回的數據,但是get_htmls沒有辦法判斷,為了方便調式和調用寫了如下兩個函數:
復制代碼 代碼如下:
function get_matches($pattern,$html,$err_msg,$multi=false,$flags=0,$offset=0){
     if(!$multi){
         if(!preg_match($pattern,$html,$matches,$flags,$offset)){
             echo $err_msg."! 錯誤信息: ".get_preg_err_msg()."/n";
             return false;
         }
     }else{
         if(!preg_match_all($pattern,$html,$matches,$flags,$offset)){
             echo $err_msg."! 錯誤信息: ".get_preg_err_msg()."/n";
             return false;
         }
     }
     return $matches;
 }
 function get_preg_err_msg(){
     $error_code = preg_last_error();
     switch($error_code){
         case PREG_NO_ERROR :
             $err_msg = 'PREG_NO_ERROR';
             break;
         case PREG_INTERNAL_ERROR:
             $err_msg = 'PREG_INTERNAL_ERROR';
             break;
         case PREG_BACKTRACK_LIMIT_ERROR:
             $err_msg = 'PREG_BACKTRACK_LIMIT_ERROR';
             break;
         case PREG_RECURSION_LIMIT_ERROR:
             $err_msg = 'PREG_RECURSION_LIMIT_ERROR';
             break;
         case PREG_BAD_UTF8_ERROR:
             $err_msg = 'PREG_BAD_UTF8_ERROR';
             break;
         case PREG_BAD_UTF8_OFFSET_ERROR:
             $err_msg = 'PREG_BAD_UTF8_OFFSET_ERROR';
             break;
         default:
             return '未知錯誤!';
     }
     return $err_msg.': '.$error_code;
 }

可以這樣調用:
復制代碼 代碼如下:
$url = 'http://www.baidu.com';
 $html = get_html($url);
 $matches = get_matches('!<a[^<]+</a>!',$html,'沒有找到鏈接',true);
 if($matches){
     var_dump($matches);
 }

或者這樣調用:
復制代碼 代碼如下:
$urls = array('http://www.baidu.com','http://www.hao123.com');
 $htmls = get_htmls($urls);
 foreach($htmls as $html){
     $matches = get_matches('!<a[^<]+</a>!',$html,'沒有找到鏈接',true);
     if($matches){
         var_dump($matches);
     }
 }

就可以得到所需的信息,無論單頁面采集還是多頁面采集,最終php還是只能處理一個頁面,由于使用get_matches了,可以對返回的值進行判斷真假,得到正確的數據,由于使用正則的時候遇到了超過正則回溯的問題,增加get_preg_err_msg來提示正則信息。

由于采集數據的時候,經常是采集列表頁,根據列表頁得到的內容頁鏈接再采集內容頁,或者更多的層次,那么循環嵌套會很多,對于代碼的控制會感覺力不從心。那我們是否可以把采集列表頁的代碼和采集內容頁的代碼,或者更多的層次的采集代碼分離開,甚至循環都簡化呢?

php技術基于curl數據采集之正則處理函數get_matches的使用,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产成人精品亚洲线观看 | 久久棋牌评测 | 四虎精品久久 | 欧美人成人亚洲专区中文字幕 | ai换脸在线全集观看 | 日韩免费精品视频 | 免费无码又爽又黄又刺激网站 | 精品四虎国产在免费观看 | 久久精品国产亚洲AV影院 | 久久re这里视频精品15 | 一本道高清不卡v免费费 | 麻豆XXXX乱女少妇精品-百度 | 香蕉鱼视频观看在线视频下载 | 国产亚洲精品久久久久5区 国产亚洲精品久久久久 | 快穿之H啪肉 | 色噜噜狠狠一区二区三区 | 狠狠婷婷综合久久久久久 | 伊人国产视频 | 热久久综合这里只有精品电影 | 99热这里精品| 国产亚洲精品久久精品6 | 日本高清无吗 | seyeye在清在线| 狠狠操天天操夜夜操 | 国产欧美一区二区精品性色tv | 99热精品一区 | 尹人综合网 | 雪恋电影完整版免费观看 | 伦理片在线线看手机版 | 日本无码欧美激情在线视频 | brazzers欧美最新版视频 | 伊人精品影院一本到综合 | 儿子好妈妈的HD3中字抢劫 | 国产一在线精品一区在线观看 | 武侠艳妇屈辱的张开双腿 | 最近中文字幕在线中文高清版 | 草莓视频app深夜福利 | 久久re热线视频精品99 | 国产人妻人伦精品9 | 美国色情三级欧美三级纸匠情挑 | 曰本熟妇乱妇色A片在线 |