php 无限分类 树形数据格式化代码


Posted in PHP onOctober 11, 2016

我们知道很多开源软件的无限分类都是采用递归的算法,但是我们知道递归即浪费时间,又浪费空间(内存),
上次我也分享了个我自己原创的无限分类生成树的方法,一热心php高手网友给我提出了宝贵的建议,我测试了一下,这段代码的时间非常之短参考: http://www.oschina.net/code/snippet_98719_11296,我再次整理了一下,发现数据库查询出数据之后,我们就已经定好了键值,因而实践中,我们一般会在model中查询出格式化成主键值对应数据的形式,因而我们可以直接用这样的数据,就少了一层循环。代码也非常简洁。

原来的代码:

function genTree($items,$id='id',$pid='pid',$son = 'children'){
  $tree = array(); //格式化的树
  $tmpMap = array(); //临时扁平数据
   
  foreach ($items as $item) {
    $tmpMap[$item[$id]] = $item;
  }
   
  foreach ($items as $item) {
    if (isset($tmpMap[$item[$pid]])) {
      $tmpMap[$item[$pid]][$son][] = &$tmpMap[$item[$id]];
    } else {
      $tree[] = &$tmpMap[$item[$id]];
    }
  }
  unset($tmpMap);
  return $tree;
}
 
$items1 = array(
    array('id' => 1, 'pid' => 0, 'name' => '一级11' ),
    array('id' => 11, 'pid' => 0, 'name' => '一级12' ),
    array('id' => 2, 'pid' => 1, 'name' => '二级21' ),
    array('id' => 10, 'pid' => 11, 'name' => '二级22' ),
    array('id' => 3, 'pid' => 1, 'name' => '二级23' ),
    array('id' => 12, 'pid' => 11, 'name' => '二级24' ),
    array('id' => 9, 'pid' => 1, 'name' => '二级25' ),
    array('id' => 14, 'pid' => 1, 'name' => '二级26' ),
    array('id' => 4, 'pid' => 9, 'name' => '三级31' ),
    array('id' => 6, 'pid' => 9, 'name' => '三级32' ),
    array('id' => 7, 'pid' => 4, 'name' => '四级41' ),
    array('id' => 8, 'pid' => 4, 'name' => '四级42' ),
    array('id' => 5, 'pid' => 4, 'name' => '四级43' ),
    array('id' => 13, 'pid' => 4, 'name' => '四级44' ),
    array('id' => 15, 'pid' => 8, 'name' => '五级51' ),
    array('id' => 16, 'pid' => 8, 'name' => '五级52' ),
    array('id' => 17, 'pid' => 8, 'name' => '五级53' ),
    array('id' => 18, 'pid' => 16, 'name' => '六级64' ),
); 
var_dump(genTree($items1));

以下是补充:

/**
 * 此方法由@Tonton 提供
 * http://my.oschina.net/u/918697
 * @date 2012-12-12
 */
function genTree5($items) {
  foreach ($items as $item)
    $items[$item['pid']]['son'][$item['id']] = &$items[$item['id']];
  return isset($items[0]['son']) ? $items[0]['son'] : array();
}
/**
 * 将数据格式化成树形结构
 * @author Xuefen.Tong
 * @param array $items
 * @return array
 */
function genTree9($items) {
  $tree = array(); //格式化好的树
  foreach ($items as $item)
    if (isset($items[$item['pid']]))
      $items[$item['pid']]['son'][] = &$items[$item['id']];
    else
      $tree[] = &$items[$item['id']];
  return $tree;
}
 
$items = array(
  1 => array('id' => 1, 'pid' => 0, 'name' => '江西省'),
  2 => array('id' => 2, 'pid' => 0, 'name' => '黑龙江省'),
  3 => array('id' => 3, 'pid' => 1, 'name' => '南昌市'),
  4 => array('id' => 4, 'pid' => 2, 'name' => '哈尔滨市'),
  5 => array('id' => 5, 'pid' => 2, 'name' => '鸡西市'),
  6 => array('id' => 6, 'pid' => 4, 'name' => '香坊区'),
  7 => array('id' => 7, 'pid' => 4, 'name' => '南岗区'),
  8 => array('id' => 8, 'pid' => 6, 'name' => '和兴路'),
  9 => array('id' => 9, 'pid' => 7, 'name' => '西大直街'),
  10 => array('id' => 10, 'pid' => 8, 'name' => '东北林业大学'),
  11 => array('id' => 11, 'pid' => 9, 'name' => '哈尔滨工业大学'),
  12 => array('id' => 12, 'pid' => 8, 'name' => '哈尔滨师范大学'),
  13 => array('id' => 13, 'pid' => 1, 'name' => '赣州市'),
  14 => array('id' => 14, 'pid' => 13, 'name' => '赣县'),
  15 => array('id' => 15, 'pid' => 13, 'name' => '于都县'),
  16 => array('id' => 16, 'pid' => 14, 'name' => '茅店镇'),
  17 => array('id' => 17, 'pid' => 14, 'name' => '大田乡'),
  18 => array('id' => 18, 'pid' => 16, 'name' => '义源村'),
  19 => array('id' => 19, 'pid' => 16, 'name' => '上坝村'),
);

print_r(genTree5($items));
print_r(genTree9($items));
//后者输出格式,前者类似,只是数组键值不一样,不过不影响数据结构

/*
Array
(
[0] => Array
  (
    [id] => 1
    [pid] => 0
    [name] => 江西省
    [son] => Array
      (
        [0] => Array
          (
            [id] => 3
            [pid] => 1
            [name] => 南昌市
          )
 
        [1] => Array
          (
            [id] => 13
            [pid] => 1
            [name] => 赣州市
            [son] => Array
              (
                [0] => Array
                  (
                    [id] => 14
                    [pid] => 13
                    [name] => 赣县
                    [son] => Array
                      (
                      [0] => Array
                        (
                          [id] => 16
                          [pid] => 14
                          [name] => 茅店镇
                          [son] => Array
                            (
                            [0] => Array
                              (
                              [id] => 18
                              [pid] => 16
                              [name] => 义源村
                              )
 
                            [1] => Array
                              (
                              [id] => 19
                              [pid] => 16
                              [name] => 上坝村
                              )
 
                            )
 
                        )
 
                      [1] => Array
                        (
                          [id] => 17
                          [pid] => 14
                          [name] => 大田乡
                        )
 
                      )
 
                  )
 
                [1] => Array
                  (
                    [id] => 15
                    [pid] => 13
                    [name] => 于都县
                  )
 
              )
 
          )
 
      )
 
  )
 
[1] => Array
  (
    [id] => 2
    [pid] => 0
    [name] => 黑龙江省
    [son] => Array
      (
        [0] => Array
          (
            [id] => 4
            [pid] => 2
            [name] => 哈尔滨市
            [son] => Array
              (
              [0] => Array
                (
                  [id] => 6
                  [pid] => 4
                  [name] => 香坊区
                  [son] => Array
                    (
                    [0] => Array
                      (
                        [id] => 8
                        [pid] => 6
                        [name] => 和兴路
                        [son] => Array
                          (
                            [0] => Array
                              (
                              [id] => 10
                              [pid] => 8
                              [name] =>
                               东北林业大学
                              )
 
                            [1] => Array
                              (
                              [id] => 12
                              [pid] => 8
                              [name] =>
                              哈尔滨师范大学
                              )
 
                          )
 
                      )
 
                    )
 
                )
 
              [1] => Array
                (
                  [id] => 7
                  [pid] => 4
                  [name] => 南岗区
                  [son] => Array
                    (
                    [0] => Array
                      (
                      [id] => 9
                      [pid] => 7
                      [name] => 西大直街
                      [son] => Array
                        (
                        [0] => Array
                          (
                          [id] => 11
                          [pid] => 9
                          [name] =>
                           哈尔滨工业大学
                          )
 
                        )
 
                      )
 
                    )
 
                )
 
              )
 
          )
 
        [1] => Array
          (
            [id] => 5
            [pid] => 2
            [name] => 鸡西市
          )
 
      )
 
  )
)*/

极其简单有效!!!非常受用!

PHP 相关文章推荐
一个改进的UBB类
Oct 09 PHP
php allow_url_include的应用和解释
Apr 22 PHP
php流量统计功能的实现代码
Sep 29 PHP
php 在windows下配置虚拟目录的方法介绍
Jun 26 PHP
php5.3 注意事项说明
Jul 01 PHP
PHP中遇到BOM、编码导致json_decode函数无法解析问题
Jul 02 PHP
PHP开发注意事项总结
Feb 04 PHP
php经典算法集锦
Nov 14 PHP
php metaphone()函数及php localeconv() 函数实例解析
May 15 PHP
phalcon model在插入或更新时会自动验证非空字段的解决办法
Dec 29 PHP
php文件上传及下载附带显示文件及目录功能
Apr 27 PHP
Redis在Laravel项目中的应用实例详解
Aug 11 PHP
PHP简单判断iPhone、iPad、Android及PC设备的方法
Oct 11 #PHP
PHP中SERIALIZE和JSON的序列化与反序列化操作区别分析
Oct 11 #PHP
php外部执行命令函数用法小结
Oct 11 #PHP
php字符串操作常见问题小结
Oct 11 #PHP
PHPCMS2008广告模板SQL注入漏洞修复
Oct 11 #PHP
php基于curl实现随机ip地址抓取内容的方法
Oct 11 #PHP
php 获取文件行数的方法总结
Oct 11 #PHP
You might like
PHP error_log()将错误信息写入一个文件(定义和用法)
2013/10/25 PHP
php接口和抽象类使用示例详解
2014/03/02 PHP
微信支付开发告警通知实例
2016/07/12 PHP
Thinkphp框架中D方法与M方法的区别
2016/12/23 PHP
php实现小程序支付完整版
2018/10/09 PHP
php 输出缓冲 Output Control用法实例详解
2020/03/03 PHP
php中数组最简单的使用方法
2020/12/27 PHP
jquery获取子节点和父节点的示例代码
2013/09/10 Javascript
javascript实现自动输出文本(打字特效)
2015/08/27 Javascript
学习JavaScript设计模式(策略模式)
2015/11/26 Javascript
分享jQuery网页元素拖拽插件
2020/12/01 Javascript
JS模拟实现方法重载示例
2016/08/03 Javascript
基于vue-ssr的静态网站生成器VuePress 初体验
2018/04/17 Javascript
解决layui中的form表单与button的点击事件冲突问题
2018/08/15 Javascript
探秘vue-rx 2.0(推荐)
2018/09/21 Javascript
VueJS 组件参数名命名与组件属性转化问题
2018/12/03 Javascript
JS为什么说async/await是generator的语法糖详解
2019/07/11 Javascript
Node.js控制台彩色输出的方法与原理实例详解
2019/12/01 Javascript
原生js实现弹窗消息动画
2020/11/20 Javascript
python自动化测试之setUp与tearDown实例
2014/09/28 Python
python+matplotlib绘制饼图散点图实例代码
2018/01/20 Python
基于pandas数据样本行列选取的方法
2018/04/20 Python
对sklearn的使用之数据集的拆分与训练详解(python3.6)
2018/12/14 Python
使用pyinstaller打包PyQt4程序遇到的问题及解决方法
2019/06/24 Python
python随机数分布random均匀分布实例
2019/11/27 Python
日本最大的药妆连锁店:Matsukiyo松本清药妆店
2017/11/23 全球购物
个性化皮包、小袋、生活配件:Mon Purse
2019/03/26 全球购物
365 Tickets英国:全球景点门票
2019/07/06 全球购物
意大利比基尼品牌:MISS BIKINI
2019/11/02 全球购物
考试作弊被抓检讨书
2014/01/10 职场文书
有趣的广告词
2014/03/18 职场文书
医院领导班子查摆问题对照检查材料思想汇报
2014/10/08 职场文书
群众路线教育实践活动学习笔记内容
2014/11/06 职场文书
2014年卫生工作总结
2014/11/27 职场文书
淘宝文案策划岗位职责
2015/04/14 职场文书
golang 实现并发求和
2021/05/08 Golang