国产精品毛片一区二区三区四区_国产亚洲中文日韩欧_91 超碰在线观看_一二三四电影在线观看免费_亚洲第一午夜福利网站_中文字幕在线永久_国产人妖的免费的视频_在线日韩视频成人网站观看_国产后入学生妹清纯妺_激情视频激情图片国产亚洲

  1. 首頁
  2. 新聞資訊
  3.  
  4. 建站經(jīng)驗
  5.  

PHP非遞歸遍歷目錄下所有文件

發(fā)布時間:2018-08-23 13:09:54 來源:
直接看代碼
<?php 

/**
 * PHP 非遞歸實現(xiàn)查詢該目錄下所有文件
 * @param unknown $dir
 * @return multitype:|multitype:string
 */
function scanfiles($dir) {
 if (! is_dir ( $dir ))
 return array ();

 // 兼容各操作系統(tǒng)
 $dir = rtrim ( str_replace ( '\\''/', $dir ), '/' ) . '/';

 // 棧,默認(rèn)值為傳入的目錄
 $dirs = array ( $dir );

 // 放置所有文件的容器
 $rt = array ();

 do {
 // 彈棧
 $dir = array_pop ( $dirs );

 // 掃描該目錄
 $tmp = scandir ( $dir );

 foreach ( $tmp as $f ) {
  // 過濾. ..
  if ($f == '.' || $f == '..')
  continue;

  // 組合當(dāng)前絕對路徑
  $path = $dir . $f;


  // 如果是目錄,壓棧。
  if (is_dir ( $path )) {
  array_push ( $dirs, $path . '/' );
  } else if (is_file ( $path )) { // 如果是文件,放入容器中
  $rt [] = $path;
  }
 }

 } while ( $dirs ); // 直到棧中沒有目錄

 return $rt;
}

?>

 

附另一篇:不用遞歸遍歷目錄下的文件

如果要遍歷某個目錄下的所有文件(包括子目錄),最首先想到的思路就是用遞歸:先處理當(dāng)前目錄,再處理當(dāng)前目錄下的子目錄。不用遞歸可不可以呢?以前學(xué)數(shù)據(jù)結(jié)構(gòu)的時候看到過,遞歸其實是利用堆棧來實現(xiàn)的,遞歸的特點就是不斷的調(diào)用自身,最后一次的調(diào)用是最先執(zhí)行完的,倒數(shù)第二次調(diào)用是其次執(zhí)行完的,依次類推,最初的調(diào)用是最后執(zhí)行完的。如果理解了遞歸的原理,其實就可以把所有用遞歸的實現(xiàn)轉(zhuǎn)化為非遞歸的實現(xiàn)。

 

用非遞歸方式遍歷某個目錄下的所有文件,思路主要分三步:

1. 創(chuàng)建一個數(shù)組,將要遍歷的這個目錄放入;(其實就是創(chuàng)建了一個棧)

2. 循環(huán)處理這個數(shù)組,循環(huán)結(jié)束的條件是數(shù)組為空;

3. 每次循環(huán),處理數(shù)組中的一個元素,并將元素刪除,如果這個元素是目錄,則將目錄下所有的子元素加入數(shù)組;

 

按照這種思路寫出的代碼如下:
 

<?php 

/**
 * 遍歷某個目錄下的所有文件
 * @param string $dir
 */
function scanAll($dir)
{
  $list = array();
  $list[] = $dir;

  while (count($list) > 0)
  {
    //彈出數(shù)組最后一個元素
    $file = array_pop($list);

    //處理當(dāng)前文件
    echo $file."\r\n";

    //如果是目錄
    if (is_dir($file))
    {
      $children = scandir($file);
      foreach ($children as $child)
      {
        if ($child !== '.' && $child !== '..')
        {
          $list[] = $file.'/'.$child;
        }
      }
    }
  }
}

?>

 

這里我并沒有認(rèn)為遞歸有多大的缺點,事實上很多情況下,用遞歸來設(shè)計還是非常簡潔可讀的,至于效率問題,除非在遞歸深度特別大的時候,才會有影響。

以下是用遞歸的實現(xiàn),作為對比:
 

<?php 

/**
 * 遍歷某個目錄下的所有文件(遞歸實現(xiàn))
 * @param string $dir
 */
function scanAll2($dir)
{
  echo $dir."\r\n";

  if (is_dir($dir))
  {
    $children = scandir($dir);
    foreach ($children as $child)
    {
      if ($child !== '.' && $child !== '..')
      {
        scanAll2($dir.'/'.$child);
      }
    }
  }
}

?>

 

運行發(fā)現(xiàn),兩個函數(shù)的結(jié)果略有不同,主要表現(xiàn)在打印的順序上。函數(shù)一運行結(jié)果的順序是倒著的,是因為壓棧的順序正好和scandir出來的順序相反了,可以將第21行改一下:
 

$children = array_reverse(scandir($file));

 

新聞資訊

 

服務(wù)項目

 

聯(lián)系我們

  • 咨詢電話:13316437003
  • 地址:廣東省深圳市福田區(qū)八卦四路中浩大廈2樓201
  • 業(yè)務(wù)咨詢:點擊這里給我發(fā)消息
  • 技術(shù)服務(wù):點擊這里給我發(fā)消息
  • 售后郵箱:service@dcnop.com
  • 技術(shù)郵箱:zcl@dcnop.com

 

微信公眾號

  • 客服:點擊這里給客服發(fā)消息

    技術(shù):點擊這里給技術(shù)發(fā)消息

    大誠網(wǎng)絡(luò)--深圳網(wǎng)站制作|深圳網(wǎng)站優(yōu)化|深圳網(wǎng)站運營

    客戶服務(wù)熱線

    0755-82400810

    在線客服