RELATEED CONSULTING
相關咨詢
選擇下列産品馬上(shàng)在線溝通(tōng)
服務時(shí)間(jiān):9:00-18:00
你(nǐ)可(kě)能遇到了下面的問題
關閉右側工具欄
使用phpQuery輕松采集網頁內(nèi)容
  • 作(zuò)者:admin
  • 發表時(shí)間(jiān):2013-07-02 14:17:10
  • 來(lái)源:未知

phpQuery是一個(gè)基于PHP的服務端開(kāi)源項目,它可(kě)以讓PHP開(kāi)發人(rén)員輕松處理(lǐ)DOM文檔內(nèi)容,比如獲取某新聞網站(zhàn)的頭條信息。更有(yǒu)意思的是,它采用了jQuery的思想,你(nǐ)可(kě)以像使用jQuery一樣處理(lǐ)頁面內(nèi)容,獲取你(nǐ)想要的頁面信息。

查看演示DEMO

采集頭條

先看一實例,現在我要采集新浪網國內(nèi)新聞的頭條,代碼如下:

include 'phpQuery/phpQuery.php';
phpQuery::newDocumentFile('http://news.sina.com.cn/china');
echo pq(".blkTop h1:eq(0)")->html();

簡單的三行(xíng)代碼,就可(kě)以獲取頭條內(nèi)容。首先在程序中包含phpQuery.php核心程序,然後調用讀取目标網頁,最後輸出對應标簽下的內(nèi)容。

pq()是一個(gè)功能強大(dà)的方法,跟jQuery的$()如出一轍,jQuery的選擇器(qì)基本上(shàng)都能使用在phpQuery上(shàng),隻要把“.”變成“->”。如上(shàng)例中,pq(".blkTop h1:eq(0)")抓取了頁面class屬性為(wèi)blkTop的DIV元素,并找到該DIV內(nèi)部的第一個(gè)h1标簽,然後用html()方法獲取h1标簽裏的內(nèi)容(帶html标簽),也就是我們要獲取的頭條信息,如果使用text()方法,則隻獲取頭條的文本內(nèi)容。當然要使用好phpQuery,關鍵是要找對文檔中對應內(nèi)容的節點。

采集文章列表

下面再來(lái)看一個(gè)例子,獲取helloweba.com網站(zhàn)的blog列表,請(qǐng)看代碼:

include 'phpQuery/phpQuery.php';
phpQuery::newDocumentFile('http://www.helloweba.com/blog.html');
$artlist = pq(".blog_li");
foreach($artlist as $li){
   echo pq($li)->find('h2')->html()."
";
}

通(tōng)過循環列表中的DIV,找出文章标題并輸出,就是這麽簡單。

解析XML文檔

假設現在有(yǒu)一個(gè)這樣的test.xml文檔:

張三22王五18

現在我要獲取名字為(wèi)張三的聯系人(rén)的年齡,代碼如下:

include 'phpQuery/phpQuery.php';
phpQuery::newDocumentFile('test.xml');
echo pq('contact > age:eq(0)');

結果輸出:22

像jQuery一樣,精準查找文檔節點,輸出節點下的內(nèi)容,解析一個(gè)XML文檔就是這麽簡單。現在你(nǐ)不必為(wèi)采集網站(zhàn)內(nèi)容而使用那(nà)些(xiē)頭疼的正則算(suàn)法、內(nèi)容替換等繁瑣的代碼了,有(yǒu)了phpQuery,一切就變得(de)輕松多(duō)了。

項目官網地址:http://code.google.com/p/phpquery/