中文字幕日韩一区二区_国产一区二区av_国产毛片av_久久久久国产一区_色婷婷电影_国产一区二区精品

使用phpQuery采集網頁的方法

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文檔:
復制代碼 代碼如下:
<?xml version="1.0" encoding="utf-8"?>
<root>
  <contact>
     <name>張三</name>
     <age>22</age>
  </contact>
  <contact>
     <name>王五</name>
     <age>18</age>
  </contact>
</root>

現在我要獲取名字為張三的聯系人的年齡,代碼如下:
復制代碼 代碼如下:
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/

php技術使用phpQuery采集網頁的方法,轉載需保留來源!

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

主站蜘蛛池模板: 亚洲精品久久久一区二区三区 | 亚洲狠狠| 岛国av免费看 | 国产1区 | 国产精品久久亚洲7777 | 毛片一区二区三区 | 亚洲精品久久 | 91成人午夜性a一级毛片 | 男人av的天堂 | 中文字幕亚洲一区 | 丝袜 亚洲 欧美 日韩 综合 | 超级黄色一级片 | 欧美视频免费在线 | 毛片日韩 | 日韩影院在线 | 成人区一区二区三区 | 99久久日韩精品免费热麻豆美女 | 日韩在线一区二区 | 亚洲福利在线观看 | 精品成人在线观看 | 天天色综 | 成人国产精品久久久 | 一区二区三区电影在线观看 | 91视在线国内在线播放酒店 | 国产精品久久一区 | 成人在线播放 | 国产精品视频一区二区三区 | 精品成人69xx.xyz | 久久精品一 | 精品色 | 一区二区电影 | 国产精品久久久久久久7电影 | 第一区在线观看免费国语入口 | 精品国产一区二区国模嫣然 | 91精品国产欧美一区二区 | 人人干在线视频 | 日本黄色片免费在线观看 | 国产欧美精品区一区二区三区 | 国产91黄色| 午夜免费精品视频 | 国内在线视频 |