基于curl數(shù)據(jù)采集之正則處理函數(shù)get_matches的使用
根據(jù)前兩篇的博文:
基于curl數(shù)據(jù)采集之單頁(yè)面采集函數(shù)get_html的使用
基于curl數(shù)據(jù)采集之單頁(yè)面并行采集函數(shù)get_htmls的使用
已經(jīng)可以得到了我們需要的html文件,現(xiàn)在需要處理得到的文件獲取到我們需要的采集的數(shù)據(jù)。
對(duì)于html文檔的解析,沒有像XML那樣的解析類,因?yàn)镠TML文檔有很多不成對(duì)的標(biāo)簽,很不嚴(yán)格。這個(gè)時(shí)候就需要采用其他的一些輔助類了,simplehtmldom是一個(gè)類似于JQuery方式操作HTML文檔的解析類。可以很方便的得到想要的數(shù)據(jù),可惜速度慢。這里不是我們這里討論的重點(diǎn),我主要使用正則來匹配我所需要的采集的數(shù)據(jù),可以很快速的得到我需要采集的信息。
考慮到get_html可以判斷返回的數(shù)據(jù),但是get_htmls沒有辦法判斷,為了方便調(diào)式和調(diào)用寫了如下兩個(gè)函數(shù):
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."! 錯(cuò)誤信息: ".get_preg_err_msg()."\n";
return false;
}
}else{
if(!preg_match_all($pattern,$html,$matches,$flags,$offset)){
echo $err_msg."! 錯(cuò)誤信息: ".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 '未知錯(cuò)誤!';
}
return $err_msg.': '.$error_code;
}
可以這樣調(diào)用:
$url = 'http://www.baidu.com';
$html = get_html($url);
$matches = get_matches('!<a[^<]+</a>!',$html,'沒有找到鏈接',true);
if($matches){
var_dump($matches);
}
或者這樣調(diào)用:
$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);
}
}
就可以得到所需的信息,無論單頁(yè)面采集還是多頁(yè)面采集,最終PHP還是只能處理一個(gè)頁(yè)面,由于使用get_matches了,可以對(duì)返回的值進(jìn)行判斷真假,得到正確的數(shù)據(jù),由于使用正則的時(shí)候遇到了超過正則回溯的問題,增加get_preg_err_msg來提示正則信息。
由于采集數(shù)據(jù)的時(shí)候,經(jīng)常是采集列表頁(yè),根據(jù)列表頁(yè)得到的內(nèi)容頁(yè)鏈接再采集內(nèi)容頁(yè),或者更多的層次,那么循環(huán)嵌套會(huì)很多,對(duì)于代碼的控制會(huì)感覺力不從心。那我們是否可以把采集列表頁(yè)的代碼和采集內(nèi)容頁(yè)的代碼,或者更多的層次的采集代碼分離開,甚至循環(huán)都簡(jiǎn)化呢?
- php使用curl抓取qq空間的訪客信息示例
- php file_get_contents抓取Gzip網(wǎng)頁(yè)亂碼的三種解決方法
- 使用PHP curl模擬瀏覽器抓取網(wǎng)站信息
- 一個(gè)PHP的遠(yuǎn)程圖片抓取函數(shù)分享
- php抓取頁(yè)面的幾種方法詳解
- PHP CURL模擬登錄新浪微博抓取頁(yè)面內(nèi)容 基于EaglePHP框架開發(fā)
- php下通過curl抓取yahoo boss 搜索結(jié)果的實(shí)現(xiàn)代碼
- php curl 登錄163郵箱并抓取郵箱好友列表的代碼(經(jīng)測(cè)試)
- php使用curl和正則表達(dá)式抓取網(wǎng)頁(yè)數(shù)據(jù)示例
相關(guān)文章
Yii2 ActiveRecord多表關(guān)聯(lián)及多表關(guān)聯(lián)搜索的實(shí)現(xiàn)
這篇文章主要介紹了Yii2 ActiveRecord多表關(guān)聯(lián)及多表關(guān)聯(lián)搜索的實(shí)現(xiàn)的相關(guān)資料,需要的朋友可以參考下2016-06-06
Laravel框架基于ajax實(shí)現(xiàn)二級(jí)聯(lián)動(dòng)功能示例
這篇文章主要介紹了Laravel框架基于ajax實(shí)現(xiàn)二級(jí)聯(lián)動(dòng)功能,結(jié)合實(shí)例形式分析了Laravel框架ajax數(shù)據(jù)讀取及聯(lián)動(dòng)菜單的構(gòu)造與使用技巧,需要的朋友可以參考下2019-01-01
php并發(fā)加鎖問題分析與設(shè)計(jì)代碼實(shí)例講解
這篇文章主要介紹了php并發(fā)加鎖問題分析與設(shè)計(jì)代碼實(shí)例講解,有感興趣的同學(xué)可以跟著研究學(xué)習(xí)下2021-02-02
php 數(shù)組處理函數(shù)extract詳解及實(shí)例代碼
php extract 函數(shù)使用數(shù)組鍵名作為變量名,使用數(shù)組鍵值作為變量值, 本函數(shù)可以處理表單提交并插入數(shù)據(jù)庫(kù)。文章向大家講解extract函數(shù)的基本使用方法及實(shí)例,需要的朋友可以參考下2016-11-11
php計(jì)算當(dāng)前程序執(zhí)行時(shí)間示例
這篇文章主要介紹了php計(jì)算當(dāng)前程序執(zhí)行時(shí)間示例,需要的朋友可以參考下2014-04-04

