-
分享一个生成文件层级树类
根据 php 递归读取文件夹生成文件树
- class Tree
- {
- public $arr = array();
- public $icon = array(
- '│',
- '├─',
- '└─'
- );
- public $ret;
- public function set_tree($arr = array())
- {
- $this->arr = $arr;
- }
- public function get_child($myid)
- {
- $newarr = array();
- if (is_array($this->arr)) {
- foreach ($this->arr as $id => $a) {
- if ($a['pid'] == $myid) {
- $newarr[$id] = $a;
- }
- }
- }
- return $newarr ? $newarr : false;
- }
- //获取带格式数组
- public function getArray($myid = 0, $sid = 0, $adds = '')
- {
- $number = 1;
- $child = $this->get_child($myid);
- if (is_array($child)) {
- $total = count($child);
- foreach ($child as $a) {
- $j = $k = '';
- if ($number == $total) {
- $j .= $this->icon[2];
- } else {
- $j .= $this->icon[1];
- $k = $adds ? $this->icon[0] : '';
- }
- $spacer = $adds ? $adds . $j : '';
- $a['name'] = $spacer . ' ' . $a['name'];
- $this->ret[] = $a;
- $fd = $adds . $k . ' ';
- $this->getArray($a['id'], $sid, $fd);
- $number++;
- }
- }
- return $this->ret;
- }
- //select
- public function get_tree($myid, $str, $sid = 0, $adds = '')
- {
- $number = 1;
- $child = $this->get_child($myid);
- if (is_array($child)) {
- $total = count($child);
- foreach ($child as $a) {
- $id = $a['id'];
- $j = $k = '';
- if ($number == $total) {
- $j .= $this->icon [2];
- } else {
- $j .= $this->icon [1];
- $k = $adds ? $this->icon [0] : '';
- }
- $spacer = $adds ? $adds . $j : '';
- $select = $id == $sid ? 'selected' : '';
- $this->ret .= sprintf($str, $id, $select, $spacer, $a['name']);
- $this->get_tree($id, $str, $sid, $adds . $k . ' ');
- $number++;
- }
- }
- return $this->ret;
- }
- //文件夹目录
- public function read_all_dir($dir, $onlyDir = true, $ignore = [])
- {
- $result = array();
- $handle = opendir($dir);
- if ($handle) {
- while (($file = readdir($handle)) !== false) {
- if (in_array($file, $ignore)) continue;
- if ($file != '.' && $file != '..') {
- $cur_path = $dir . DIRECTORY_SEPARATOR . $file;
- if (is_dir($cur_path)) {
- $result[$file] = $this->read_all_dir($cur_path, $onlyDir);
- } else {
- if (!$onlyDir) {
- $result[] = $file;
- }
- }
- }
- }
- closedir($handle);
- }
- return $result;
- }
- //数组转换
- public function arrshift($array, $pid = 0)
- {
- static $r = [];
- static $index = 1;
- if (is_array($array) && count($array) > 0) {
- foreach ($array as $k => $v) {
- $r[] = array(
- 'id' => $index,
- 'pid' => $pid,
- 'name' => is_array($v) ? $k : $v
- );
- $index++;
- $this->arrshift($v, $index - 1);
- }
- }
- return $r;
- }
- }
使用示例
- $tree = new Tree ();
- //文件夹遍历
- $data = $tree->read_all_dir(realpath('../file_dir'), false, ['.git', '.idea', 'vendor']);
- //转换成[['id','pid','name']]的二维数组
- $data = $tree->arrshift($data);
- $tree->set_tree($data);
- $data = $tree->getArray();
- foreach ($data as $value) {
- echo $value['name'];
- echo '<br/>';
- echo '<br/>';
- }
出处:http://www.phpfensi.com/php/20220620/21108.html
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比
一款纯 JS 实现的轻量化图片编辑器
关于开发 VS Code 插件遇到的 workbench.scm.
前端设计模式——观察者模式
前端设计模式——中介者模式
创建型-原型模式