加入收藏 | 设为首页 | 会员中心 | 我要投稿 北几岛 (https://www.beijidao.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

基于PHP采集数据入库程序(二)

发布时间:2021-07-06 06:02:13 所属栏目:大数据 来源: https://www.jb51.cc
导读:在上篇? 基于PHP采集数据入库程序(一) ?中提到采集新闻信息页的列表数据,接下来讲讲关于采集新闻具体内容 这是上篇博客的最终数据表截图: 接下来要做的操作就是从数据库中读取所需要采集的URL,进行页面抓取就行 新建一个content表 不过需要注意的一点是

在上篇?基于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 class="dataWrap">(.*)</dd>/iUs";
    preg_match($pattern,$content,1)">$info);获取内容存放info
    echo $title=$row[1]."<br/>"$content=$info[0]."<hr/>";

    插入数据库
    $add="insert into content(title,content) value('$title','$content')"$add);

    $sql2="select * from list where id>$id order by id asc limit 1"$result2=$sql2$row2=$result2);取得对应的URL地址
    if($row2['id']){
        echo "<script>window.location='content.PHP?id=$row2[0]'</script>";
    }

?>

这样子我们所要的新闻内容就采集入库了,接下来只需要对数据的一些样式进行整理就行了。

(编辑:北几岛)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读