当前位置: 首页 > 图文教程 > 网络编程 > PHP > PHP 抓取新浪读书频道的小说并生成txt电子书的代码

PHP
Php部分常见问题总结
从零开始 教你如何搭建Discuz!4.1论坛(图)
php分页函数
php计数器的设计与实现
PHP初学者头疼问题总结
WinXP + Apache +PHP5 + MySQL + phpMyAdmin安装全功略
PHP截取中文字符串的问题
删除无限级目录与文件代码共享
生成静态页面的PHP类
转换中文为unicode 转换unicode到正常文本
玩转图像函数库—常见图形操作
Windows下PHP5和Apache的安装与配置
apache+mysql+php+ssl服务器之完全安装攻略
PHP.MVC的模板标签系统(一)
PHP.MVC的模板标签系统(二)
PHP.MVC的模板标签系统(三)
PHP.MVC的模板标签系统(四)
PHP.MVC的模板标签系统(五)
Windows下的PHP5.0安装配制详解
PHP中的串行化变量和序列化对象

PHP 抓取新浪读书频道的小说并生成txt电子书的代码


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2010-01-10   浏览: 118 ::
收藏到网摘: n/a

想看什么电子书,先去新浪读书搜索,然后填入对应的参数即可
复制代码 代码如下:

/* Author: Yang Yu <[email protected]> */
//想看什么电子书,先去新浪读书搜索,然后填入对应的参数即可
//http://vip.book.sina.com.cn/
//电子书参数
$array_book[0] = 38884; //小说id
$array_book[1] = 22172; //章节起始id
$array_book[2] = 32533; //章节结束id
$array_book[3] = '中国特种部队生存实录:狼牙'; //小说名字
//匹配参数
$title_pre = "/<h1>(.*?)<\/h1>/"; //标题部分
$contents_pre = "/<div id=\"contTxt\" class=\"contTxt1\">(.*?)<\/div>/"; //内容部分
//生成电子书
for( $i = $array_book[1]; $i <= $array_book[2]; $i++){
$url = "http://vip.book.sina.com.cn/book/chapter_{$array_book[0]}_{$i}.html";
$html = file_get_contents($url);
preg_match_all($title_pre,$html,$title);
preg_match_all($contents_pre,$html,$contents);
$fh = fopen($array_book[3].'.txt','a+');
$write_contents = $title[1][0]."\r\n".str_replace('</p>',"\r\n",str_replace('<p>',' ',$contents[1][0]))."\r\n";
if( fwrite($fh,$write_contents) ){
echo '第'.$i.'节抓取完毕< /br>';
}
fclose($fh);
}