使用phpQuery採集網頁的方法_PHP教程

來源:互聯網
上載者:User
phpQuery是一個基於PHP的服務端開源項目,它可以讓PHP開發人員輕鬆處理DOM文檔內容,比如擷取某新聞網站的頭條資訊。更有意思的是,它採用了jQuery的思想,你可以像使用jQuery一樣處理頁面內容,擷取你想要的頁面資訊。
採集頭條
先看一執行個體,現在我要採集新浪網國內新聞的頭條,代碼如下:
複製代碼 代碼如下:
include 'phpQuery/phpQuery.php';
phpQuery::newDocumentFile('http://www.jb51.net');
echo pq(".blkTop h1:eq(0)")->html();

簡單的三行代碼,就可以擷取頭條內容。首先在程式中包含phpQuery.php核心程式,然後調用讀取目標網頁,最後輸出對應標籤下的內容。
pq()是一個功能強大的方法,跟jQuery的$()如出一轍,jQuery的選取器基本上都能使用在phpQuery上,只要把“.”變成“->”。如上例中,pq(“.blkTop h1:eq(0)”)抓取了頁面class屬性為blkTop的DIV元素,並找到該DIV內部的第一個h1標籤,然後用html()方法擷取h1標籤裡的內容(帶html標籤),也就是我們要擷取的頭條資訊,如果使用text()方法,則只擷取頭條的常值內容。當然要使用好phpQuery,關鍵是要找對文檔中對應內容的節點。
採集文章列表
下面再來看一個例子,擷取helloweba.com網站的blog列表,請看代碼:
複製代碼 代碼如下:
include 'phpQuery/phpQuery.php';
phpQuery::newDocumentFile('http://www.jb51.net');
$artlist = pq(".blog_li");
foreach($artlist as $li){
echo pq($li)->find('h2')->html()."";
}

通過迴圈列表中的DIV,找出文章標題並輸出,就是這麼簡單。
解析XML文檔
假設現在有一個這樣的test.xml文檔:
複製代碼 代碼如下:



張三
22


王五
18



現在我要擷取名字為張三的連絡人的年齡,代碼如下:
複製代碼 代碼如下:
include 'phpQuery/phpQuery.php';
phpQuery::newDocumentFile('test.xml');
echo pq('contact > age:eq(0)');
結果輸出:22

像jQuery一樣,精準尋找文檔節點,輸出節點下的內容,解析一個XML文檔就是這麼簡單。現在你不必為採集網站內容而使用那些頭疼的正則演算法、內容替換等繁瑣的代碼了,有了phpQuery,一切就變得輕鬆多了。
phpquery項目官網地址:http://code.google.com/p/phpquery/

http://www.bkjia.com/PHPjc/825181.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/825181.htmlTechArticlephpQuery是一個基於PHP的服務端開源項目,它可以讓PHP開發人員輕鬆處理DOM文檔內容,比如擷取某新聞網站的頭條資訊。更有意思的是,它採用...

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.