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

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

WBOY
WBOY원래의
2016-06-06 19:31:561132검색

高效目录遍历,不用递归,不用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);
    }
성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.