本文實例總結了PHP遍歷目錄文件的常用方法。分享給大家供大家參考,具體如下:
測試算法
算法1.簡短系
foreach(glob('*.*') as $filename){  echo 'Filename:'.$filename.;}算法2.規矩系
if($handle = opendir('C://Inetpub//wwwroot//test//')){  echo "Files:/n";  while (false !== ($file = readdir($handle))){    echo "$file/n";  }  closedir($handle);}算法3.函數系
function tree($directory){  $mydir=dir($directory);  while($file=$mydir->read()){    if((is_dir("$directory/$file")) AND ($file!=".") AND ($file!=".."))    {      echo "$file/n";      tree("$directory/$file");    } else    echo "$file/n";  }  echo "/n";  $mydir->close();}tree("C://Inetpub//wwwroot//test//");算法4.函數系II
function listDir($dir){  if(is_dir($dir)){    if ($dh = opendir($dir)) {      while (($file= readdir($dh)) !== false){        if((is_dir($dir."/".$file)) && $file!="." && $file!=".."){          echo "文件名:",$file;          listDir($dir."/".$file."/");        } else{          if($file!="." && $file!=".."){            echo $file;          }        }      }      closedir($dh);    }  }}listDir("C://Inetpub//wwwroot//test//");算法5.遞歸系
function file_list($dir,$pattern=""){  $arr=array();  $dir_handle=opendir($dir);  if($dir_handle)  {    while(($file=readdir($dir_handle))!==false)    {      if($file==='.' || $file==='..')      {        continue;      }      $tmp=realpath($dir.'/'.$file);      if(is_dir($tmp))      {        $retArr=file_list($tmp,$pattern);        if(!emptyempty($retArr))        {          $arr[]=$retArr;        }      } else      {        if($pattern==="" || preg_match($pattern,$tmp))        {          $arr[]=$tmp;        }      }    }    closedir($dir_handle);  }  return $arr;}print_r(file_list("C://Inetpub//wwwroot//test//"));測試方法
我們采取在測試代碼的頭部和尾部添加如下的內容來檢測執行時間,并測試5次取平均結果作為最終成績。
$stime=microtime(true);//測試代碼//......//......$etime=microtime(true);$total=($etime-$stime)*1000;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的模式,我們將代碼寫成這樣就可以了。
foreach(glob('*.需要的擴展名') as $filename){  echo 'Filename:'.$filename.;}結語
不管作為一個代碼新手還是一個資深的程序員,在堆砌代碼的時候,更應該關注程序的效率和安全。
請不要忽略任何一種可能,也請不要讓孩子般的代碼成為拖累服務器的罪魁禍首。
希望本文所述對大家PHP程序設計有所幫助。
新聞熱點
疑難解答
圖片精選