php抓取百度快照、百度收录、百度热词程序代码
发布:smiling 来源: PHP粉丝网 添加日期:2013-12-31 16:16:17 浏览: 评论:0
如果大家稍加仔细看一下就能发现一个问题,我们下面几个抓取百度收录或快照或热词的程序中都有一个函数file_get_contents(),他是php采集网页常用的哦。
- <?
- /*
- 抓取百度收录代码
- */
- function baidu($s){
- $baidu="http://www.baidu.com/s?wd=site%3A".$s;
- $site=file_get_contents($baidu);
- //$site=iconv("gb2312", "UTF-8", $site);
- ereg("找到相关网页(.*)篇,", $site,$count);
- $count=str_replace("找到相关网页","",$count);
- $count=str_replace("篇,","",$count);
- $count=str_replace("约","",$count);
- $count=str_replace(",","",$count);
- return $count[0];
- }
- echo baidu(www.hzhuti.com); //获取好主题在百度中的收录数量
- ?>
获取百度的热词
- <?php
- /**
- * * @user 小杰
- * @return array 返回百度的热词数据(数组返回)
- */
- function getBaiduHotKeyWord()
- {
- $templateRss = file_get_contents('http://top.baidu.com/rss_xml.php?p=top10');
- If (preg_match('/<table>(.*)</table>/is', $templateRss, $_description)) {
- $templateRss = $_description [0];
- $templateRss = str_replace("&", "&", $templateRss);
- }
- $templateRss = "<?xml version="1.0" encoding="GBK"?>" . $templateRss;
- $xml = simplexml_load_String($templateRss);
- foreach ($xml->tbody->tr as $temp) {
- if (!emptyempty ($temp->td->a)) {
- $keyArray [] = trim(($temp->td->a));
- }
- }
- return $keyArray;
- }
- print_r(getBaiduHotKeyWord());
这是在网上找的,稍微修改了下,将下面代码写入php文件,百度收录和百度快照时间
- <?php
- $domain = “http://www.phpfensi.com/nokia/5230/ *欲查询的域名*/
- $site_url = ‘http://www.phpfensi.com/s?wd=site%3A’;
- $all = $site_url.$domain; /*域名所有收录的网址*/
- $today = $all.’&lm=1′; /*域名今日收录的网址*/
- $utf_pattern = “/找到相关结果数(.*)个/”;
- $kz_pattern = “/<span class=”g”>(.*)</span>/”; /*用以匹配快照日期的字符串*/
- $times = “/d{4}-d{1,2}-d{1,2}/”; /*匹配快照日期的正则表达式,如:2011-8-4*/
- $s0 = @file_get_contents($all); /*将site:www.phpfensi.net的网页置入$s0字符串中*/
- $s1 = @file_get_contents($today);
- preg_match($utf_pattern,$s0,$all_num); /*匹配”找到相关结果数*个”*/
- preg_match($utf_pattern,$s1,$today_num);
- preg_match($kz_pattern,$s0,$temp);
- preg_match($times,$temp[0],$screenshot);
- if($all_num[1] == “”)
- $all_num[1] = 0;
- if($today_num[1] == “”)
- $today_num[1] = 0;
- if($screenshot[0] == “”)
- $screenshot[0] = “暂无快照”;
- ?>
- <html>
- <head>
- <title>Test</title>
- </head>
- <body>
- <table>
- <tr>
- <td>日期</td><td>百度收录</td><td>百度今日收录</td><td>百度快照日期</td>
- </tr>
- <tr>
- <td><?php echo date(‘m月d日G时’);?> </td><td><?php echo $all_num[1]; ?></td><td><?php echo $today_num[1]; ?></td><td><?php echo $screenshot[0]; ?></td>
- </tr>
- </table>
- <p>百度收录:<a href=”<?php echo $all; ?>” target=”_blank”><?php echo $all_num[1]; ?></a></p>
- <p>百度今日收录:<a href=”<?php echo $today; ?>” target=”_blank”><?php echo $today_num[1]; ?></a></p>
- <p>百度快照日期:<a href=”<?php echo $all; ?>”><?php echo $screenshot[0]; ?></a></p>
- </body>
- </html>
上面的方法未经过严格考虑,如果服务器不支持file_get_contents函数我们就无法操作了,所以还可以利用curl操作,这个更方便可以模仿用户哦。
Tags: 快照 百度 收录
相关文章
- ·php获取网站百度快照日期的方法(2021-06-14)
- ·php生成百度站点地图sitemap类函数(2014-08-20)
- ·PHP计算百度地图两个GPS坐标之间的距离代码(2015-04-08)
- ·百度UEDITOR编辑器上传图片添加加水印修改(2015-05-09)
- ·php实现计算百度地图坐标之间距离的方法(2019-07-28)
- ·PHP实现仿百度文库,豆丁在线文档效果(word,excel,ppt转flash)(2019-11-26)
- ·用PHP实现腾讯地图和百度地图的相互转换范例(2020-03-28)
- ·百度ping方法使用示例 自动ping百度(2020-08-31)
- ·php实现的百度搜索某地天气的小偷代码(2020-11-20)
- ·php生成百度sitemap站点地图类函数实例(2021-04-17)
- ·php获取百度收录、百度热词及百度快照的方法(2021-05-19)
- ·php检查页面是否被百度收录(2021-06-23)
- ·php 调用百度sms来发送短信的实现示例(2021-11-01)
- ·PHP利用百度ai实现文本和图片审核(2021-11-22)
- ·php根据地址获取百度地图经纬度的实例方法(2021-12-14)
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)