php fseek函数读取大文件两种方法
php读取大文件,使用fseek函数是最为普遍的方式,它不需要将文件的内容全部读入内存,而是直接通过指针来操作,所以效率是相当高效的.在使用fseek来对文件进行操作时,也有多种不同的方法,效率可能也是略有差别的,下面是常用的两种方法.
方法一:
首先通过fseek找到文件的最后一位EOF,然后找最后一行的起始位置,取这一行的数据,再找次一行的起始位置,再取这一行的位置,依次类推,直到找到了$num行。实现代码如下:
整个代码执行完成耗时0.0095(s)
functiontail($fp,$n,$base=5) { assert($n>0); $pos=$n+1; $lines=array(); while(count($lines)<=$n){ try{ fseek($fp,-$pos,SEEK_END); }catch(Exception$e){ fseek(0); break; } $pos*=$base; while(!feof($fp)){ array_unshift($lines,fgets($fp)); } } returnarray_slice($lines,0,$n); } var_dump(tail(fopen("access.log","r+"),10));
方法二:
还是采用fseek的方式从文件最后开始读,但这时不是一位一位的读,而是一块一块的读,每读一块数据时,就将读取后的数据放在一个buf里,然后通过换行符(n)的个数来判断是否已经读完最后$num行数据.实现代码如下
整个代码执行完成耗时0.0009(s).
$fp=fopen($file,"r"); $line=10; $pos=-2; $t=""; $data=""; while($line>0){ while($t!="n"){ fseek($fp,$pos,SEEK_END); $t=fgetc($fp); $pos--; } $t=""; $data.=fgets($fp); $line--; } fclose($fp); echo$data
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!