>백엔드 개발 >PHP 튜토리얼 >PHP 读取大文件的X行到Y行的内容

PHP 读取大文件的X行到Y行的内容

WBOY
WBOY원래의
2016-06-20 13:02:081140검색

PHP 读取大文件的X行到Y行的内容

最新写了个小程序,需要读取一个文件的几行内容,但是文件比较大,所以研究了下php读取大文件的几行内容的方法,写了一个方法,代码如下(加了注释):

function getFileLines($filename, $startLine = 1, $endLine=50, $method='rb') {
$content = array();
$count = $endLine - $startLine;
if(version_compare(PHP_VERSION, '5.1.0', '>=')){// 判断php版本(因为要用到SplFileObject,PHP>=5.1.0)
        $fp = new SplFileObject($filename, $method);
        $fp->seek($startLine-1);// 转到第N行, seek方法参数从0开始计数
                for($i = 0; $i current();// current()获取当前行内容
                        $fp->next();// 下一行
 }
}else{//PHP

<p> </p>

<p>Ps:</p>

<p>上面都没加"读取到末尾的判断":!$fp->eof() 或者 !feof($fp),加上这个判断影响效率,自己加上测试很多很多很多行的运行时间就晓得了,而且这里加上也完全没必要。</p>

<p> </p>

<p>从上面的函数就可以看出来使用SplFileObject比下面的fgets要快多了,特别是文件行数非常多、并且要取后面的内容的时候。fgets要两个循环才可以,并且要循环$endLine次。</p>

<p> </p>

<p>此方法花了不少功夫,测试了很多中写法,就是想得出效率最高的方法。哪位觉得有值得改进的欢迎赐教。</p>

<p> </p>

<p>使用,返回35270行-35280行的内容:</p>

<p> </p>

<pre config="brush:php;toolbar:false;" data-pbcklang="" data-pbcktabsize="">
echo '<pre class="brush:php;toolbar:false">';var_dump(getFileLines('test.php',35270,35280));

 


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.