基于PHP的简单采集数据入库程序【续篇】

5年以前  |  阅读数:1047 次  |  编程语言: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,$info);//获取内容存放info
      echo $title=$row[1]."<br/>";
      echo $content=$info[0]."<hr/>";

      //插入数据库
      $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 "<script>window.location='content.php?id=$row2[0]'</script>";
      }

    ?>

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

 相关文章:
PHP分页显示制作详细讲解
SSH 登录失败:Host key verification failed
获取IMSI
将二进制数据转为16进制以便显示
获取IMEI
文件下载
贪吃蛇
双位运算符
PHP自定义函数获取搜索引擎来源关键字的方法
Java生成UUID
发送邮件
年的日历图
提取后缀名
在Zeus Web Server中安装PHP语言支持
让你成为最历害的git提交人
Yii2汉字转拼音类的实例代码
再谈PHP中单双引号的区别详解
指定应用ID以获取对应的应用名称
Python 2与Python 3版本和编码的对比
php封装的page分页类完整实例