当前位置:Gxlcms > PHP教程 > 使用PHP遍历文件夹与子目录的函数代码

使用PHP遍历文件夹与子目录的函数代码

时间:2021-07-01 10:21:17 帮助过:30人阅读

我们要使用的函数有 Scandir,它的作用是列出指定路径中的文件和目录,就像 Dir 一样。


> 与更强力的 Glob() 函数,作用是以数组的形式返回与指定模式相匹配的文件名或目录。
> 友情提醒,千万别像小邪那样在电脑前面呆太长时间,否则就会像小邪一样得见鬼的高血糖。

一. 遍历单层文件夹:

> 在扫描单层文件夹的问题是,两个函数的结果虽有不同,不过表现是相差不大的。
> Scandir 函数会提供额外两行,分别是 “.” 和 “..” ,而 Glob 则是没有的。
代码如下:

  1. <br>function get_dir_scandir(){ <br>$tree = array(); <br>foreach(scandir('./') as $single){ <br>echo $single."<br/>\r\n"; <br>} <br>} <br>get_dir_scandir(); <br><br>function get_dir_glob(){ <br>$tree = array(); <br>foreach(glob('./*') as $single){ <br>echo $single."<br/>\r\n"; <br>} <br>} <br>get_dir_glob(); <br> <br>二. 递归遍历文件树: <br><br>> 在递归扫描文件夹树的问题上,还是 Glob 函数的表现好一点,很准确的说。 <br>> Scandir 函数会莫名其妙扫描两次 ../ 处的文件,也就是说如果小邪有俩文件。 <br>> ../b.php 和 ../a.php,结果就会在扫描报告上面出现两次,很是奇怪。 <br><span><u></u></span> 代码如下:<pre class="brush:php;toolbar:false layui-box layui-code-view layui-code-notepad"><ol class="layui-code-ol"><li><br>//Update at 2010.07.25 - 以下代码作废 <br>$path = '..'; <br>function get_filetree_scandir($path){ <br>$tree = array(); <br>foreach(scandir($path) as $single){ <br>if(is_dir('../'.$single)){ <br>$tree = array_merge($tree,get_filetree($single)); <br>} <br>else{ <br>$tree[] = '../'.$single; <br>} <br>} <br>return $tree; <br>} <br>print_r(get_filetree_scandir($path)); <br><br>//Update at 2010.07.25 - 以下为新代码 <br>$path = './'; <br>function get_filetree_scandir($path){ <br>$result = array(); <br>$temp = array(); <br>if (!is_dir($path)||!is_readable($path)) return null; //检测目录有效性 <br>$allfiles = scandir($path); //获取目录下所有文件与文件夹 <br>foreach ($allfiles as $filename) { //遍历一遍目录下的文件与文件夹 <br>if (in_array($filename,array('.','..'))) continue; //无视 . 与 .. <br>$fullname = $path.'/'.$filename; //得到完整文件路径 <br>if (is_dir($fullname)) { //是目录的话继续递归 <br>$result[$filename] = get_filetree_scandir($fullname); //递归开始 <br>} <br>else { <br>$temp[] = $filename; //如果是文件,就存入数组 <br>} <br>} <br>foreach ($temp as $tmp) { //把临时数组的内容存入保存结果的数组 <br>$result[] = $tmp; //这样可以让文件夹排前面,文件在后面 <br>} <br>return $result; <br>} <br>print_r(get_filetree_scandir($path)); <br> <br>> Glob 函数扫描灰常准确,并且会自动按照字母排好顺序,貌似是最佳方案。 <br><span><u></u></span> 代码如下:<pre class="brush:php;toolbar:false layui-box layui-code-view layui-code-notepad"><ol class="layui-code-ol"><li><br>$path = '..'; <br>function get_filetree($path){ <br>$tree = array(); <br>foreach(glob($path.'/*') as $single){ <br>if(is_dir($single)){ <br>$tree = array_merge($tree,get_filetree($single)); <br>} <br>else{ <br>$tree[] = $single; <br>} <br>} <br>return $tree; <br>} <br>print_r(get_filetree($path)); <br><p></p></li><li> </li><li> </li></ol></pre></li></ol></pre>

人气教程排行