本文实例讲述了php读取目录树的实现方法。分享给大家供大家参考,具体如下:
前一阵时间面试xx公司笔试题中竟然有这样一道题:
使用php列出目录树!
当时一看就懵逼了!基本的思路还是有的,不过是使用递归算法,但对php操作目录文件的方法却不是很了解,所以今天好好补习一下!
解题思路:
1. 列出目录中的文件。
2. 判断是否是目录,如果是目录就继续递归。
3. 将所有文件名,存入多维数组
<?phpfunction 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(操作系统$file个人检讨书怎么写name, array('.', '..'))) { continue; } //路径加文件名 $fullname = $pathname.'/'.$filename; //如果是目录的话就继续遍历这个目录 if(is_dir(考核评估$fullname)) { //将这个目录中的文件信息存入到数组中 $result[$fullname] = recurdir($fullname); }el { //如果是文件就先存入临时变量 $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); }el { $str.=$l.$val."<br/>"; } } $l = ''; return $str;}$beautifultree = beautifultree($tree);echo "<pre>";print_r($beautiful);echo "</pre>";
显示结果
更多关于php相关内容感兴趣的读者可查看本站专题:《php目录操作技巧汇总》、《php文件操作总结》、《php常用遍历算法与技巧总结》、《php数据结构与算法教程》、《php程序设计算法总结》、《php数组(array)操作技巧大全》、《php字符串(string)用法总结》及《p仰小俯大原理图hp常见数据库操作技巧汇总》
希望本文所述对大家php程序设计有所帮助。
本文发布于:2023-04-07 11:25:55,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/zuowen/0283423ba8df0c8f987ec4519d9529b5.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文word下载地址:PHP读取目录树的实现方法分析.doc
本文 PDF 下载地址:PHP读取目录树的实现方法分析.pdf
留言与评论(共有 0 条评论) |