注册 登录
编程论坛 Linux系统管理

PHP遍历目录文件的常用方法小结

堕落黑天使 发布于 2017-02-13 17:03, 2984 次点击
本文实例总结了PHP遍历目录文件的常用方法。分享给大家供大家参考,具体如下:
测试算法(源代码经过本站工具http://tools.进行格式化处理,以便于读者阅读)
算法1.简短系

1   foreach(glob('*.*') as $filename)
2   {
3     echo 'Filename:'.$filename.;
4   }
算法2.规矩系

1   if($handle = opendir('C:\\Inetpub\\wwwroot\\test\\')){
2     echo "Files:\n";
3     while (false !== ($file = readdir($handle))){
4       echo "$file\n";
5     }
6     closedir($handle);
7   }
算法3.函数系

1   function tree($directory)
2   {
3     $mydir=dir($directory);
4     while($file=$mydir->read()){
5       if((is_dir("$directory/$file")) AND ($file!=".") AND ($file!=".."))
6       {
7         echo "$file\n";
8         tree("$directory/$file");
9       } else
10      echo "$file\n";
11    }
12    echo "\n";
13    $mydir->close();
14  }
15  tree("C:\\Inetpub\\wwwroot\\test\\");
算法4.函数系II

1   function listDir($dir){
2     if(is_dir($dir)){
3       if ($dh = opendir($dir)) {
4         while (($file= readdir($dh)) !== false){
5           if((is_dir($dir."/".$file)) && $file!="." && $file!=".."){
6             echo "文件名:",$file;
7             listDir($dir."/".$file."/");
8           } else{
9             if($file!="." && $file!=".."){
10              echo $file;
11            }
12          }
13        }
14        closedir($dh);
15      }
16    }
17  }
18  listDir("C:\\Inetpub\\wwwroot\\test\\");
算法5.递归系

1   function file_list($dir,$pattern="")
2   {
3     $arr=array();
4     $dir_handle=opendir($dir);
5     if($dir_handle)
6     {
7       while(($file=readdir($dir_handle))!==false)
8       {
9         if($file==='.' || $file==='..')
10        {
11          continue;
12        }
13        $tmp=realpath($dir.'/'.$file);
14        if(is_dir($tmp))
15        {
16          $retArr=file_list($tmp,$pattern);
17          if(!emptyempty($retArr))
18          {
19            $arr[]=$retArr;
20          }
21        } else
22        {
23          if($pattern==="" || preg_match($pattern,$tmp))
24          {
25            $arr[]=$tmp;
26          }
27        }
28      }
29      closedir($dir_handle);
30    }
31    return $arr;
32  }
33  print_r(file_list("C:\\Inetpub\\wwwroot\\test\\"));
测试方法
我们采取在测试代码的头部和尾部添加如下的内容来检测执行时间,并测试5次取平均结果作为最终成绩。

1   $stime=microtime(true);
2   //测试代码
3   //......
4   //......
5   $etime=microtime(true);
6   $total=($etime-$stime)*1000;
7   echo "{$total} Millisecond(s)";
测试结果:
算法1
算法1在浏览器能正确输出所有项目,5次测验耗费的时间分别是:
平均用时=3803.618621824 毫秒
算法2
算法2在浏览器也能正确输出所有项目,但在开头会给出“..”(上级目录)的信息。5次测验耗费的时间分别是:
平均用时=381.0853481294 毫秒
算法3
算法3在浏览器能正确输出所有项目,也仍会给出“..”(上级目录)的信息。5次测验耗费的时间分别是:
平均用时=24299.2805485 毫秒
算法4
算法4和算法3类似,在浏览器能正确输出所有项目,5次测验耗费的时间分别是:
平均用时=24020.66812516 毫秒
算法5
算法5曾一度让我以为IIS又出问题了。虽说它在浏览器能正确输出所有项目,但数据的结果默认为数组。5次测验耗费的时间分别是:
平均用时=61411.31243706 毫秒
测试总结
根据测试结果,我们很容易得出下面的速度排名。
算法2 > 算法1 > 算法4 >  算法3 > 算法5
为什么算法2要比其他算法都高效一些呢?
实际上是因为算法中只使用了php中内置用来读取目录内容的函数“readdir()” 。除了算法1以外,其他算法在引用readdir()的时候,为了弥补函数的先天不足,干了很多其他的事情。
如果说,我们需要指定扩展名的列举目录内所有文件的话。Rt推荐使用算法1的模式,我们将代码写成这样就可以了。

1   foreach(glob('*.需要的扩展名') as $filename)
2   {
3     echo 'Filename:'.$filename.;
4   }

更多内容:http://www.网站建设
0 回复
1