• 技术文章 >后端开发 >php教程

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

    2016-05-17 08:58:56原创306
    需要读取一个文件的几行内容,但是文件比较大,所以研究了下php读取大文件的几行内容的方法,写了一个方法,代码如下(加了注释):
    缓存文件如果能够保存在一行, 而利用算法读取指定的行数, 自然会比全部读出来挑选要快得多. 但php似乎这方面比较弱, 不太好操作. 就算使用SplFileObject仍然不是特别可取, 内存压力存在.

    复制代码 代码如下:

    $fp->seek($startLine - 1);


    经过测试, 此行代码在8MB文本中游走到最后一行, 内存占用为49KB, 还算不错. 换成fopen方式用fgets跳过的模式, 则花费29KB的内存, fopen还是占优势.

    复制代码 代码如下:

    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类功能比较好.
    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:大文件
    上一篇:PHP实现简单聊天室(附源码)_php技巧 下一篇:解析PHP留言本模块主要功能的函数说明(代码可实现)_php技巧
    php培训_php实战培训【立即报名】-php中文网第20期

    相关文章推荐

    • 【活动】充值PHP中文网VIP即送云服务器• 分享一个有趣的php版本的扫雷!• PHP网站安装程序制作的原理、步骤、注意事项和示例代码_PHP教程• mysql 搜索之简单应用_PHP教程• 一个可以删除字符串中HTML标记的PHP函数_PHP教程• 一个ubbcode的函数,速度很快._PHP教程
    1/1

    PHP中文网