-
-
/** 返回文件从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 $content[]=$fp->current();// current()获取当前行内容
- $fp->next();// 下一行
- }
- }else{//PHP $fp = fopen($filename, $method);
- if(!$fp) return 'error:can not read file';
- for ($i=1;$i fgets($fp);
- }
- for($i;$i $content[]=fgets($fp);// 读取文件行内容
- }
- fclose($fp);
- }
- return array_filter($content); // array_filter过滤:false,null,''
- }
-
复制代码
说明:
上面都没加”读取到末尾的判断”:!$fp->eof() 或者 !feof($fp),加上这个判断影响效率,自己加上测试很多很多很多行的运行时间就晓得了,而且这里加上也完全没必要。
从上面的函数就可以看出来使用SplFileObject比下面的fgets要快多了,特别是文件行数非常多、并且要取后面的内容的时候。
fgets要两个循环才可以,并且要循环$endLine次。
此方法花了不少功夫,测试了很多中写法,就是想得出效率最高的方法。哪位觉得有值得改进的欢迎赐教。
使用,返回35270行-35280行的内容:
代码:
-
-
echo '
'; Salin selepas log masuk
- var_dump(getFileLines('test.php',35270,35280));
- echo '';
复制代码
|