您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關(guān)PHP遍歷目錄文件的常用方法有哪些的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過來看看吧。
具體如下:
測(cè)試算法
算法1.簡(jiǎn)短系
foreach(glob('*.*') as $filename) { echo 'Filename:'.$filename.; }
算法2.規(guī)矩系
if($handle = opendir('C:\\Inetpub\\wwwroot\\test\\')){ echo "Files:\n"; while (false !== ($file = readdir($handle))){ echo "$file\n"; } closedir($handle); }
算法3.函數(shù)系
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.函數(shù)系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\\"));
測(cè)試方法
我們采取在測(cè)試代碼的頭部和尾部添加如下的內(nèi)容來檢測(cè)執(zhí)行時(shí)間,并測(cè)試5次取平均結(jié)果作為最終成績(jī)。
$stime=microtime(true); //測(cè)試代碼 //...... //...... $etime=microtime(true); $total=($etime-$stime)*1000; echo "{$total} Millisecond(s)";
測(cè)試結(jié)果:
算法1
算法1在瀏覽器能正確輸出所有項(xiàng)目,5次測(cè)驗(yàn)耗費(fèi)的時(shí)間分別是:
平均用時(shí)=3803.618621824 毫秒
算法2
算法2在瀏覽器也能正確輸出所有項(xiàng)目,但在開頭會(huì)給出“..”(上級(jí)目錄)的信息。5次測(cè)驗(yàn)耗費(fèi)的時(shí)間分別是:
平均用時(shí)=381.0853481294 毫秒
算法3
算法3在瀏覽器能正確輸出所有項(xiàng)目,也仍會(huì)給出“..”(上級(jí)目錄)的信息。5次測(cè)驗(yàn)耗費(fèi)的時(shí)間分別是:
平均用時(shí)=24299.2805485 毫秒
算法4
算法4和算法3類似,在瀏覽器能正確輸出所有項(xiàng)目,5次測(cè)驗(yàn)耗費(fèi)的時(shí)間分別是:
平均用時(shí)=24020.66812516 毫秒
算法5
算法5曾一度讓我以為IIS又出問題了。雖說它在瀏覽器能正確輸出所有項(xiàng)目,但數(shù)據(jù)的結(jié)果默認(rèn)為數(shù)組。5次測(cè)驗(yàn)耗費(fèi)的時(shí)間分別是:
平均用時(shí)=61411.31243706 毫秒
測(cè)試總結(jié)
根據(jù)測(cè)試結(jié)果,我們很容易得出下面的速度排名。
算法2 > 算法1 > 算法4 > 算法3 > 算法5
為什么算法2要比其他算法都高效一些呢?
實(shí)際上是因?yàn)樗惴ㄖ兄皇褂昧藀hp中內(nèi)置用來讀取目錄內(nèi)容的函數(shù)“readdir()” 。除了算法1以外,其他算法在引用readdir()的時(shí)候,為了彌補(bǔ)函數(shù)的先天不足,干了很多其他的事情。
如果說,我們需要指定擴(kuò)展名的列舉目錄內(nèi)所有文件的話。Rt推薦使用算法1的模式,我們將代碼寫成這樣就可以了。
foreach(glob('*.需要的擴(kuò)展名') as $filename) { echo 'Filename:'.$filename.; }
感謝各位的閱讀!關(guān)于“PHP遍歷目錄文件的常用方法有哪些”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。