基於PHP的簡單採集資料入庫程式【續篇】,php採集入庫續篇_PHP教程

來源:互聯網
上載者:User

基於PHP的簡單採集資料入庫程式【續篇】,php採集入庫續篇


在上篇文章中,我們已經採集新聞資訊頁的列表資料,接下來要做的操作就是從資料庫中讀取所需要採集的URL,進行頁面抓取就行

建立一個content表

不過需要注意的一點是,不能再採用採集URL這種id遞增的方法去採集,因為資料表中可能出現id斷續,比如id=9,id=11,當採集到id=10的時候,URL是空白的,這樣可能會導致採集到了空欄位。

這裡用到的一個技巧是資料庫的查詢語句,在我們採集完第一條資料的時候,判斷資料庫裡是否還有大於此id的id編號,若有,讀取一條,查詢資訊重複上面的工作。

具體代碼如下:

<?php    include_once("conn.php");  $id=(int)$_GET['id'];  $sql="select * from list where id=$id";  $result=mysql_query($sql);  $row=mysql_fetch_array($result);//取得對應的url地址  $content=file_get_contents($row['url']);  $pattern="/
 
(.*)<\/dd>/iUs"; preg_match($pattern, $content,$info);//擷取內容存放info echo $title=$row[1]."
"; echo $content=$info[0].""; //插入資料庫 $add="insert into content(title,content) value('$title','$content')"; mysql_query($add); $sql2="select * from list where id>$id order by id asc limit 1"; $result2=mysql_query($sql2); $row2=mysql_fetch_array($result2);//取得對應的url地址 if($row2['id']){ echo ""; }?>

這樣子我們所要的新聞內容就採集入庫了,接下來只需要對資料的一些樣式進行整理就行了。


PHP採集入庫問題

php 裡有$nr = implode(‘#’,$arr) 方法 ,就可以 了
不過上面的組成的是“內容1#內容2”,沒有最後面的一個#,要是必須的話
就是$nr = implode('#',$arr).'#'

在笨的方法,就是用
foreach( $arr as $vl){
$nr.=$vl."#";
}
參考資料:$
 

PHP採集入庫問題

mysql_connect() //先串連你的資料庫
mysql_select_db() //選擇你的資料庫
mysql_query("insert into 你的表 (地址,標題) values ('$tmp[1][$i]',$tmp[2][$i])");//OK了,搞定!
 

http://www.bkjia.com/PHPjc/854355.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/854355.htmlTechArticle基於PHP的簡單採集資料入庫程式【續篇】,php採集入庫續篇 在上篇文章中,我們已經採集新聞資訊頁的列表資料,接下來要做的操作就是從...

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.