微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

PHP 读取大文件的X行到Y行内容的实现代码

需要读取一个文件的几行内容,但是文件比较大,所以研究了下PHP读取大文件的几行内容方法,写了一个方法代码如下(加了注释):
缓存文件如果能够保存在一行,而利用算法读取指定的行数,自然会比全部读出来挑选要快得多. 但PHP似乎这方面比较弱,不太好操作. 就算使用SplFileObject仍然不是特别可取,内存压力存在. <div class="codetitle"><a style="CURSOR: pointer" data="14736" class="copybut" id="copybut14736" onclick="doCopy('code14736')"> 代码如下:

<div class="codebody" id="code14736">
$fp->seek($startLine - 1);
经过测试,此行代码在8MB文本中游走到最后一行,内存占用为49KB,还算不错. 换成fopen方式用fgets跳过的模式,则花费29KB的内存,fopen还是占优势. <div class="codetitle"><a style="CURSOR: pointer" data="6450" class="copybut" id="copybut6450" onclick="doCopy('code6450')"> 代码如下:
<div class="codebody" id="code6450">
function getFileLines($filename,$startLine = 1,$endLine = 50,$method = 'rb'){
$content = array(); if (version_compare(PHP_VERSION,'5.1.0','>=')) { // 判断PHP版本(因为要用到SplFileObject,PHP>=5.1.0)
$count = $endLine - $startLine;
$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,''
}
效果不错,SplFileObject类功能比较好.

原文地址:https://www.jb51.cc/php/26046.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐