Heim >php教程 >php手册 >高效目录遍历,不用递归,不用DirectoryIterator

高效目录遍历,不用递归,不用DirectoryIterator

WBOY
WBOYOriginal
2016-06-06 19:31:561128Durchsuche

高效目录遍历,不用递归,不用DirectoryIterator 补充:传入的参数$dir为要遍历目录的绝对路径, 无 /** 快速查找目录、文件 */ public static function find($dir) { if(!is_dir($dir)) # 如果$dir变量不是一个目录,直接返回false return false; $dirs[] =

高效目录遍历,不用递归,不用DirectoryIterator
补充:传入的参数 $dir 为要遍历目录的绝对路径,
    /** 快速查找目录、文件 */
    public static function find($dir)
    {
        if(!is_dir($dir)) # 如果$dir变量不是一个目录,直接返回false
            return false;
        $dirs[] = '';     # 用于记录目录
        $files = array(); # 用于记录文件
        while(list($k,$path)=each($dirs))
        {
            $absDirPath = "$dir/$path";     # 当前要遍历的目录的绝对路径
            $handle = opendir($absDirPath); # 打开目录句柄
            readdir($handle);               # 先调用两次 readdir() 过滤 . 和 ..
            readdir($handle);               # 避免在 while 循环中 if 判断
            while(false !== $item=readdir($handle))
            {
                $relPath = "$path/$item";   # 子项目相对路径
                $absPath = "$dir/$relPath"; # 子项目绝对路径
                if(is_dir($absPath))        # 如果是一个目录,则存入到数组 $dirs
                    $dirs[] = $relPath;
                else                        # 否则是一个文件,则存入到数组 $files
                    $files[] = $relPath;
            }
            closedir($handle); # 关闭目录句柄
        }
        return array($dirs,$files);
    }
Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn