Heim > Backend-Entwicklung > PHP-Tutorial > php 递归遍历文件树代码_PHP教程

php 递归遍历文件树代码_PHP教程

WBOY
Freigeben: 2016-07-13 16:55:11
Original
1332 Leute haben es durchsucht

在递归扫描文件夹树的问题上,还是 Glob 函数的表现好一点,很准确的说。 > Scandir 函数会莫名其妙扫描两次 ../ 处的文件,也就是说如果小邪有俩文件。


> ../b.php教程 和 ../a.php,结果就会在扫描报告上面出现两次,很是奇怪。

 

 代码如下 复制代码

//Update at 2010.07.25 - 以下代码作废
$path = '..';
function get_filetree_scandir($path){
$tree = array();
foreach(scandir($path) as $single){
if(is_dir('../'.$single)){
$tree = array_merge($tree,get_filetree($single));
}
else{
$tree[] = '../'.$single;
}
}
return $tree;
}
print_r(get_filetree_scandir($path));

//Update at 2010.07.25 - 以下为新代码
$path = './';
function get_filetree_scandir($path){
$result = array();
$temp = array();
if (!is_dir($path)||!is_readable($path)) return null; //检测目录有效性
$allfiles = scandir($path); //获取目录下所有文件与文件夹
foreach ($allfiles as $filename) { //遍历一遍目录下的文件与文件夹
if (in_array($filename,array('.','..'))) continue; //无视 . 与 ..
$fullname = $path.'/'.$filename; //得到完整文件路径
if (is_dir($fullname)) { //是目录的话继续递归
$result[$filename] = get_filetree_scandir($fullname); //递归开始
}
else {
$temp[] = $filename; //如果是文件,就存入数组
}
}
foreach ($temp as $tmp) { //把临时数组的内容存入保存结果的数组
$result[] = $tmp; //这样可以让文件夹排前面,文件在后面
}
return $result;
}
print_r(get_filetree_scandir($path));

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/631703.htmlTechArticle在递归扫描文件夹树的问题上,还是 Glob 函数的表现好一点,很准确的说。 > Scandir 函数会莫名其妙扫描两次 ../ 处的文件,也就是说如果小...
Quelle:php.cn
Erklärung dieser Website
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage