本文实例讲述了php读取目录树的实现方法。分享给大家供大家参考,具体如下:
前一阵时间面试xx公司笔试题中竟然有这样一道题:
使用php列出目录树!
当时一看就懵逼了!基本的思路还是有的,不过是使用递归算法,但对php操作目录文件的方法却不是很了解,所以今天好好补习一下!
解题思路:
1. 列出目录中的文件。
2. 判断是否是目录,如果是目录就继续递归。
3. 将所有文件名,存入多维数组
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
|
<?php function recurdir( $pathname ) { //将结果保存在result变量中 $result = array (); $temp = array (); //判断传入的变量是否是目录 if (! is_dir ( $pathname ) || ! is_readable ( $pathname )) { return null; } //取出目录中的文件和子目录名,使用scandir函数 $allfiles = scandir( $pathname ); //遍历他们 foreach ( $allfiles as $filename ) { //判断是否是.和..因为这两个东西神马也不是。。。 if (in_array( $filename , array ( '.' , '..' ))) { continue ; } //路径加文件名 $fullname = $pathname . '/' . $filename ; //如果是目录的话就继续遍历这个目录 if ( is_dir ( $fullname )) { //将这个目录中的文件信息存入到数组中 $result [ $fullname ] = recurdir( $fullname ); } else { //如果是文件就先存入临时变量 $temp [] = $fullname ; } } //取出文件 if ( $temp ) { foreach ( $temp as $f ) { $result [] = $f ; } } return $result ; } //验证一下这个函数是否好用! $tree = recurdir( 'cart_ajax' ); echo "<pre>" ; print_r( $tree ); echo "</pre>" ; ?> |
cart_ajax文件夹结构
js文件夹下的内容
显示结果
大功告成了!目录的级别确实是这样的,不过看起来也太low了吧!稍微美化一下吧!
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
function beautifultree( $arr , $l = '-|' ) { static $l = '' ; static $str = '' ; //遍历刚才得到的目录树 foreach ( $arr as $key => $val ) { //如果是个数组,也就代表它是个目录,那么就在它的子文件中加入-|来表示是下一级吧 if ( is_array ( $arr [ $key ])) { $str .= $l . $key . "<br/>" ; $l .= '-|' ; beautifultree( $arr [ $key ], $l ); } else { $str .= $l . $val . "<br/>" ; } } $l = '' ; return $str ; } $beautifultree = beautifultree( $tree ); echo "<pre>" ; print_r( $beautiful ); echo "</pre>" ; |
显示结果
希望本文所述对大家php程序设计有所帮助。
原文链接:https://blog.csdn.net/sinat_21125451/article/details/51316749