本文实例讲述了php读取目录树的实现方法。分享给大家供大家参考,具体如下:
前一阵时间面试xx公司笔试题中竟然有这样一道题:
使用php列出目录树!
当时一看就懵逼了!基本的思路还是有的,不过是使用递归算法,但对php操作目录文件的方法却不是很了解,所以今天好好补习一下!
解题思路:
1. 列出目录中的文件。
2. 判断是否是目录,如果是目录就继续递归。
3. 将所有文件名,存入多维数组<?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了吧!稍微美化一下吧!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
|