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

WBOY
Libérer: 2016-06-20 13:02:51
original
889 Les gens l'ont consulté

PHP高效目录遍历,不用递归,不用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);
}
Copier après la connexion


Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!