这篇文章主要介绍了PHP读取目录树的实现方法,结合实例形式分析了php针对文件目录结构的遍历、读取操作实现技巧,需要的朋友可以参考下
本文实例讲述了PHP读取目录树的实现方法。分享给大家供大家参考,具体如下:
前一阵时间面试XX公司笔试题中竟然有这样一道题:
使用PHP列出目录树!
当时一看就懵逼了!基本的思路还是有的,不过是使用递归算法,但对PHP操作目录文件的方法却不是很了解,所以今天好好补习一下!
解题思路:
- 列出目录中的文件。
- 判断是否是目录,如果是目录就继续递归。
- 将所有文件名,存入多维数组
"; print_r($tree); echo ""; ?>
cart_ajax文件夹结构
嗨学网
js文件夹下的内容
嗨学网
显示结果
嗨学网
大功告成了!目录的级别确实是这样的,不过看起来也太low了吧!稍微美化一下吧!
function beautifulTree($arr, $l = ‘-|’)
{
static $l = ‘’;
static
s
t
r
=
′
′
;
/
/
遍
历
刚
才
得
到
的
目
录
树
f
o
r
e
a
c
h
(
str = ''; //遍历刚才得到的目录树 foreach(
str=′′;//遍历刚才得到的目录树foreach(arr as
k
e
y
=
>
key=>
key=>val) {
//如果是个数组,也就代表它是个目录,那么就在它的子文件中加入-|来表示是下一级吧
if(is_array(
a
r
r
[
arr[
arr[key])) {
s
t
r
.
=
str.=
str.=l.$key."
";
l
.
=
′
−
∣
′
;
b
e
a
u
t
i
f
u
l
T
r
e
e
(
l.='-|'; beautifulTree(
l.=′−∣′;beautifulTree(arr[$key], $l);
}else {
s
t
r
.
=
str.=
str.=l.$val."
";
}
}
$l = ‘’;
return $str;
}
b
e
a
u
t
i
f
u
l
T
r
e
e
=
b
e
a
u
t
i
f
u
l
T
r
e
e
(
beautifulTree = beautifulTree(
beautifulTree=beautifulTree(tree);
echo “
”;”;
print_r($beautiful);
echo “
显示结果
嗨学网
更多关于PHP相关内容感兴趣的读者可查看本站专题:《PHP目录操作技巧汇总》、《php文件操作总结》、《PHP常用遍历算法与技巧总结》、《PHP数据结构与算法教程》、《php程序设计算法总结》、《PHP数组(Array)操作技巧大全》、《php字符串(string)用法总结》及《php常见数据库操作技巧汇总》
希望本文所述对大家PHP程序设计有所帮助。http://www.piaodoo.com/thread-3554-1-1.html 来源http://www.piaodoo.com