分享一例php无限级分类生成树的代码,学习下php无限级分类的实现方法,有需要的朋友参考下。
 
   一段非常精简的PHP无限极分类生成树方法,巧在引用。
 
   例子,php实现无限级分类。
 
   代码示例:
 
   <?php
 
   function generateTree($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' => 3, 'name' => '长丰县'),
 
   5 => array('id' => 5, 'pid' => 1, 'name' => '安庆市'),
 
   );
 
   print_r(generateTree($items));
 
   打印的结果:
 
   Array
 
   (
 
   [0] => Array
 
   (
 
   [id] => 1
 
   [pid] => 0
 
   [name] => 安徽省
 
   [son] => Array
 
   (
 
   [0] => Array
 
   (
 
   [id] => 3
 
   [pid] => 1
 
   [name] => 合肥市
 
   [son] => Array
 
   (
 
   [0] => Array
 
   (
 
   [id] => 4
 
   [pid] => 3
 
   [name] => 长丰县
 
   )
 
   )
 
   )
 
   [1] => Array
 
   (
 
   [id] => 5
 
   [pid] => 1
 
   [name] => 安庆市
 
   )
 
   )
 
   )
 
   [1] => Array
 
   (
 
   [id] => 2
 
   [pid] => 0
 
   [name] => 浙江省
 
   )
 
   )
 
   上面生成树方法还可以精简到5行:
 
   代码示例:
 
   <?php
 
   function generateTree($items){
 
   foreach($items as $item)
 
   $items[$item['pid']]['son'][$item['id']] = &$items[$item['id']];
 
   return isset($items[0]['son']) ? $items[0]['son'] : array();
 
   }
 
   上面这种无限极分类数据树形结构化的方法值得借鉴。
 
   感觉这段代码实际用途并不明显啊,想取出格式化的树形数据还是要递归啊:
 
   代码示例: www.lefeng123.com
 
   /**
 
   * 如何取数据格式化的树形数据
 
   * @site <
 
   */
 
   $tree = generateTree($items);
 
   function getTreeData($tree){
 
   foreach($tree as $t){
 
   echo $t['name'].'<br>';
 
   if(isset($t['son'])){
 
   getTreeData($t['son']);
 
   }
 
   }
 
   }
 
   getTreeData($tree);

PHP无限级分类生成树实例代码的更多相关文章

  1. 使用BERT进行情感分类预测及代码实例

    文章目录 0. BERT介绍 1. BERT配置 1.1. clone BERT 代码 1.2. 数据处理 1.2.1预训练模型 1.2.2数据集 训练集 测试集 开发集 2. 修改代码 2.1 加入 ...

  2. php利用递归函数实现无限级分类

    相信很多学php的很多小伙伴都会尝试做一个网上商城作为提升自己技术的一种途径.各种对商品分类,商品名之类的操作应该是得心应手,那么就可以尝试下无限级分类列表的制作了. 什么是无限级分类? 无限级分类是 ...

  3. thinkphp中如何实现无限级分类?

    thinkphp中如何实现无限级分类? 一.总结 1.数据表设计+递归算法 二.php实现无限级分类实例总结 1.数据库数据如下: 2.任务需求:给一个id,求自己和所有父亲. 3.实现代码如下:th ...

  4. MyBatis无限级分类实现的两种方法--自关联与map集合

    1.这回先创建数据库吧 下表cid是CategoryId的缩写,cname是CategoryName的缩写,pid是parentId的缩写 无限级分类一般都包含这三个属性,至少也要包含cid和pid才 ...

  5. PHP读取超大文件的实例代码

    数据量大带来的问题就是单个文件很大,能够打开这个文件相当不容易,记事本就不要指望了,果断死机   去年年底的各种网站帐号信息的数据库泄漏,很是给力啊,趁机也下载了几个数据库,准备学学数据分析家来分析一 ...

  6. PHP无限极分类生成树方法,无限分级

    你还在用浪费时间又浪费内存的递归遍历无限极分类吗,看了该篇文章,我觉得你应该换换了.这是我在OSChina上看到的一段非常精简的PHP无限极分类生成树方法,巧在引用,整理分享了. function g ...

  7. (实用篇)PHP递归实现无限级分类

    在一些复杂的系统中,要求对信息栏目进行无限级的分类,以增强系统的灵活性.那么PHP是如何实现无限级分类的呢?我们在本文中使用递归算法并结合mysql数据表实现无限级分类. 在一些复杂的系统中,要求对信 ...

  8. PHP无限级分类-递归(不推荐)

    [http://www.helloweba.com/view-blog-204.html] 在一些复杂的系统中,要求对信息栏目进行无限级的分类,以增强系统的灵活性.那么PHP是如何实现无限级分类的呢? ...

  9. PHP无限极分类生成树方法

    你还在用浪费时间又浪费内存的递归遍历无限极分类吗,看了该篇文章,我觉得你应该换换了.这是我在OSChina上看到的一段非常精简的PHP无限极分类生成树方法,整理分享了. function genera ...

随机推荐

  1. SSH的内网穿透

    SSH的内网穿透 1.内网:     ssh -N -f -R 2222:127.0.0.1:22 lienzh@我的PC的IP2.外网:     ssh -p 2222 root@localhost ...

  2. 反编译工具 使用.NET JustDecompile来反编译你的程序代码

    原文地址:http://www.it165.net/pro/html/201310/7383.html 前言 在项目的进行中有时会碰到需要去了解由第三方所开发的程序代码或者因为年久已经遗失原始码的程序 ...

  3. bzoj2730 [HNOI2012]矿场搭建 (UVAlive5135 Mining Your Own Business)

    2730: [HNOI2012]矿场搭建 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1147  Solved: 528[Submit][Statu ...

  4. DeepLearnToolbox使用总结

    GitHub链接:DeepLearnToolbox DeepLearnToolbox A Matlab toolbox for Deep Learning. Deep Learning is a ne ...

  5. View inflate方法和LayoutInflater inflate方法的区别详解

    原创文章,转载请注明出处:http://www.cnblogs.com/baipengzhan/p/6257510.html 我们在Android开发中,对于将布局填充成View对象,最常用的两种办法 ...

  6. jquery width(), innerWidth(), outerWidth() 区别

    #div1 { width: 100px; height: 100px; border: 5px black solid; padding: 10px; margin: 10px; backgroun ...

  7. swift - use backslash to add the value in the string

    There’s an even simpler way to include values in strings: Write the value in parentheses, and write ...

  8. ceph主要数据结构解析2-Rados.h文件

    (1)文件系统id结构:16个字符组成 struct ceph_fsid { unsigned char fsid[16]; }; 以及对应的比较函数: static inline int ceph_ ...

  9. Android TagFlowLayout完全解析 一款针对Tag的布局(转)

    一.概述 本文之前,先提一下关于上篇博文的100多万访问量请无视,博文被刷,我也很郁闷,本来想把那个文章放到草稿箱,结果放不进去,还把日期弄更新了,实属无奈. ok,开始今天的博文,今天要说的是Tag ...

  10. 【字符串匹配】UVALive 4670 模板题

    给一个文本T,和n个模板字符串,都是由小写字母组成,问这些字符串那些在字符串中出现的次数最多,输出最多的次数以及相应的字符串. AC自动机的模板题,递归输出的时候改成累加次数统计数组cnt即可. 大白 ...