抓取和分析一個檔案是非常簡單的事。這個教程將通過一個例子帶領你一步一步地去實現它。讓我們開始吧!
首先,我首必須決定我們將抓取的URL地址。可以通過在指令碼中設定或通過$QUERY_STRING傳遞。為了簡
單起見,讓我們將變數直接設在指令碼中。
$url = http://www.php.net;
?>
第二步,我們抓取指定檔案,並且通過file()函數將它存在一個數組裡。
$url = http://www.php.net;
$lines_array = file($url);
?>
好了,現在在數組裡已經有了檔案了。但是,我們想分析的文本可能不全在一行裡面。為瞭解決這個檔案,我們可以簡單地將數組$lines_array轉化成一個字串。我們可以使用implode(x,y)函數來實現它。如果在後面你想用explode(將字串變數數組),將x設成"|"或"!"或其它類似的分隔字元可能會更好。但是出於我們的目的,最好將x設成空格。y是另一個必要的參數,因為它是你想用implode()處理的數組。
$url = http://www.php.net;
$lines_array = file($url);
$lines_string = implode(, $lines_array);
?>
現在,抓取工作就做完了,下面該進行分析了。出於這個例子的目的,我們想得到在到之間的所有東西。為了分析出字串,我們還需要叫做正規運算式的東西。
$url = http://www.php.net;
$lines_array = file($url);
$lines_string = implode(, $lines_array);
eregi("(.*)", $lines_string, $head);
?>
讓我們看一下代碼。正如你所見,eregi()函數按下面的格式執行:
eregi("(.*)", $lines_string, $head);
"(.*)"表示所有東西,可以解釋為,"分析在和間的所以東西"。$lines_string是我們正在分析的字串,$head是分析後的結果存放的數組。
最後,我們可以輸資料。因為僅在和間存在一個執行個體,我們可以安全的假設數組中僅存在著一個元素,而且就是我們想要的。讓我們把它列印出來吧。
$url = http://www.php.net;
$lines_array = file($url);
$lines_string = implode(, $lines_array);
eregi("(.*)", $lines_string, $head);
echo $head[0];
?>
這就是全部的代碼了。
轉自WeberDev.com
http://www.bkjia.com/PHPjc/532087.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/532087.htmlTechArticle抓取和分析一個檔案是非常簡單的事。這個教程將通過一個例子帶領你一步一步地去實現它。讓我們開始吧! 首先,我首必須決定我們將抓...