php file_get_contents()读取采集远程文件内容
我们来看php手册讲述关于file_get_contents() 函数把整个文件读入一个字符串中和 file() 一样,不同的是 file_get_contents() 把文件读入一个字符串.
file_get_contents() 函数是用于将文件的内容读入到一个字符串中的首选方法
上面是帮助手册的是一次性把内容全部读入内存了,后面的实例我们也会讲到
_get_contents可以将远程文件读入为一个字符串,
而文件行的分隔就是]rn]
explode将字符串按]rn]分隔
实例代码如下:
$shadu_url = "http://localhost/demo.html" ;
$shadu_str = file_get_contents ( $shadu_url );
$line_arr = explode ( "rn" , $shadu_str );远程请求地址,返回的处理结果信息为字符串,各字段以‘|’隔开,行与行用‘rn’隔开
分别返回内容为,id,name,time,email
内容示例
1|simaopig|2009-04-01|demo@simaopig.com
2|xiaoxiaozi|2009-04-02|demo@xiaoxiaozi.com
如我想要获得每个字段操作如下
实例代码如下:
$shadu_url = "http://localhost/demo.html" ;
$shadu_str = file_get_contents ( $shadu_url );
$line_arr = explode ( "rn" , $shadu_str );
$result = array ();
if ( empty empty ( $line_arr ))
{
return array ();
}
foreach ( $line_arr as $line_str )
{
$record_arr = explode ( "|" , $line_str );
if ( $record_arr [0] == "-1" )
{
// log
continue ;
}
$data = array ();
$data [ 'id' ] = $record_arr [0];
$data [ 'name' ] = $record_arr [1];
$data [ 'time' ] = $record_arr [2];
$data [ 'email' ] = $record_arr [3];
$result [] = $data ;
}
var_dump( $result );结果自己查看吧,哈哈.
采集html页面的内容
实例代码如下:
<?php
//全国,判断条件是$REQUEST_URI是否含有html
if (! strpos ( $_SERVER [ "REQUEST_URI" ], ".html" ))
{
$page = "http://qq.ip138.com/weather/" ;
$html = file_get_contents ( $page , 'r' );
$pattern = "/<B>全国主要城市、县当天和未来五天天气趋势预报在线查询</B>(.*?)<center style=" padding:3px ">/si" ;
//正则匹配之间的html
preg_match( $pattern , $html , $pg );
echo "" ;
//正则替换远程地址为本地地址
$p =preg_replace( '//weather/(w+)/index.htm/' , 'tq.php/$1.html' , $pg [1]);
echo $p ;
}
//省,判断条件是$REQUEST_URI是否含有?
else if (! strpos ( $_SERVER [ "REQUEST_URI" ], "?" )){
//yoyo推荐的使用分割获得数据,这里是获得省份名称
$province = explode ( "/" , $_SERVER [ "REQUEST_URI" ]);
$province = explode ( "." , $province [ count ( $province )-1]);
$province = $province [0];
//被注释掉的是我自己写出来的正则,感觉写的不好,但效果等同上面
//preg_match('/[^/]+[.(html)]$/',$_SERVER["REQUEST_URI"],$pro);
//$province=preg_replace('/.html/','',$pro[0]);
$page = "http://qq.ip138.com/weather/" . $province . "/index.htm" ;
//获取html数据之前先尝试打开页面,防止恶意输入地址导致出错
if (!@ fopen ( $page , "r" )) {
die ( "对不起,该地址不存在!<a href=javascript:history.back(1)>点击这里返回</a>" );
exit (0);
}
$html = file_get_contents ( $page , 'r' );
$pattern = "/五天天气趋势预报</B>(.*?)请输入输入市/si" ;
preg_match( $pattern , $html , $pg );
echo "" ;
//正则替换,获取省份,城市
$p =preg_replace( '//weather/(w+)/(w+).htm/' , '$2.html?pro=$1' , $pg [1]);
echo $p ;
}
else {
//市,通过get传递省份
$pro = $_REQUEST [ 'pro' ];
$city = explode ( "/" , $_SERVER [ "REQUEST_URI" ]);
$city = explode ( "." , $city [ count ( $city )-1]);
$city = $city [0];
//preg_match('/[^/]+[.(html)]+[?]/',$_SERVER["REQUEST_URI"],$cit);
//$city=preg_replace('/.html?/','',$cit[0]);
$page = "http://qq.ip138.com/weather/" . $pro . "/" . $city . ".htm" ;
if (!@ fopen ( $page , "r" )) {
die ( "对不起,该地址不存在!<a href=javascript:history.back(1)>点击这里返回</a>" );
exit (0);
}
$html = file_get_contents ( $page , 'r' );
$pattern = "/五天天气趋势预报</B>(.*?)请输入输入市/si" ;
preg_match( $pattern , $html , $pg );
echo "" ;
//获取真实的图片地址
$p =preg_replace( '//image//' , 'http://qq.ip138.com/image/' , $pg [1]);
echo $p ;
}
?>