PHP读取大文件

今天在博客上看到别人写的一段PHP读取大文件的方法:

PHP读取大文件
/** 
* 返回文件从X行到Y行的内容(支持php5、php4) * @param string $filename 文件名 * @param int $startLine 开始的行数 * @param int $endLine 结束的行数 * @return string
*/ function getFileLines($filename, $startLine = 1, $endLine=50, $method=‘rb‘) { $content = array(); $count = $endLine - $startLine; // 判断php版本(因为要用到SplFileObject,PHP>=5.1.0) if(version_compare(PHP_VERSION, ‘5.1.0‘, ‘>=‘)){ $fp = new SplFileObject($filename, $method); $fp->seek($startLine-1);// 转到第N行, seek方法参数从0开始计数 for($i = 0; $i <= $count; ++$i) { $content[]=$fp->current();// current()获取当前行内容 $fp->next();// 下一行 } }else{//PHP<5.1 $fp = fopen($filename, $method); if(!$fp) return ‘error:can not read file‘; for ($i=1;$i<$startLine;++$i) {// 跳过前$startLine行 fgets($fp); } for($i;$i<=$endLine;++$i){ $content[]=fgets($fp);// 读取文件行内容 } fclose($fp); } return array_filter($content); // array_filter过滤:false,null,‘‘ }
PHP读取大文件

PHP4的版本感觉写的不是很好,因为 for ($i=1;$i<$startLine;++$i) {// 跳过前$startLine行 fgets($fp); }这段代码实际上还是去读取文件了,效率不高,可以考虑用fseek设置文件指针到开始读取的位置,然后再开始读取到结束($endLine)的位置

PHP读取大文件

上一篇:[转]jQuery选择器 (详解)


下一篇:SpringMVC+Freemarker+JSTL支持