PHP에서 대용량 파일을 읽기 위한 SplFileObject 클래스 사용법에 대한 자세한 설명

WBOY
풀어 주다: 2016-07-25 08:53:36
원래의
2261명이 탐색했습니다.
  1. /** 返回文件从X行到Y行的内容(支持php5、php4)
  2. * @param string $filename 文件名
  3. * @param int $startLine 开始的行数
  4. * @param int $endLine 结束的行数
  5. * @return string
  6. */
  7. function getFileLines($filename, $startLine = 1, $endLine=50, $method='rb') {
  8. $content = array();
  9. $count = $endLine - $startLine;
  10. // 判断php版本(因为要用到SplFileObject,PHP>=5.1.0)
  11. if(version_compare(PHP_VERSION, '5.1.0', '>=')){
  12. $fp = new SplFileObject($filename, $method);
  13. $fp->seek($startLine-1);// 转到第N行, seek方法参数从0开始计数
  14. for($i = 0; $i <= $count; $i) {
  15. $content[]=$fp->current();// current()获取当前行内容
  16. $fp->next();// 下一行
  17. }
  18. }else{//PHP<5.1
  19. $fp = fopen($filename, $method);
  20. if(!$fp) return 'error:can not read file';
  21. for ($i=1;$i<$startLine; $i) {// 跳过前$startLine行
  22. fgets($fp);
  23. }
  24. for($i;$i<=$endLine; $i){
  25. $content[]=fgets($fp);// 读取文件行内容
  26. }
  27. fclose($fp);
  28. }
  29. return array_filter($content); // array_filter过滤:false,null,''
  30. }
复制代码

说明: 上面都没加”读取到末尾的判断”:!$fp->eof() 或者 !feof($fp),加上这个判断影响效率,自己加上测试很多很多很多行的运行时间就晓得了,而且这里加上也完全没必要。 从上面的函数就可以看出来使用SplFileObject比下面的fgets要快多了,特别是文件行数非常多、并且要取后面的内容的时候。 fgets要两个循环才可以,并且要循环$endLine次。 此方法花了不少功夫,测试了很多中写法,就是想得出效率最高的方法。哪位觉得有值得改进的欢迎赐教。 使用,返回35270行-35280行的内容: 代码:

  1. echo '
    ';</li>
    <li>var_dump(getFileLines('test.php',35270,35280));</li>
    <li>echo '
    ';
复制代码


원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿