php分类树
class Category{
public $sonName;
public $parentName;
public function __consturt($id,$parent_id){
$this->sonName = $id;
$this->parentName = $parent_id;
} /**
* 根据传递的父类ID获取所有的子级分类
* 组合一维数组
* @param [type] $data 分类数组
* @param integer $pid 父类id
* @param integer $lev 父类所属层级
* @return [type] 格式化后的数组信息
*/
public function unlimitedForLevel($data, $pid = 0, $lev = 0) {
$arr = array(); foreach($data as $v) {
if($v[$this->parentName] == $pid) {
$v['level'] = $lev + 1;
$arr[] = $v;
$arr = array_merge($arr, self::unlimitedForLevel($data, $v[$this->sonName], $lev + 1));
}
} return $arr;
} /**
* 根据传递的父类ID获取所有的子级分类
* 组合多维数组
* @param [type] $data 分类数组
* @param integer $pid 父类id
* @return [type] 格式化后的数组信息
*/
public function unlimitedForLayer($data, $pid = 0) {
$arr = array(); foreach($data as $v) {
if($v[$this->parentName] == $pid) {
$v['children'] = self::unlimitedForLayer($data, $v[$this->sonName]);
$arr[] = $v;
}
} return $arr;
} /**
* 根据传递子类ID获取所有的父级分类
* @param [type] $data 分类数组
* @param integer $id 子类id
* @return [type] 父类数组信息
*/
public function getParents($data, $id) {
$arr = array(); foreach($data as $v) {
if($v[$this->sonName] == $id) {
$arr[] = $v;
$arr = array_merge(self::getParents($data, $v[$this->parentName]), $arr);
}
} return $arr;
} /**
* 根据传递的父类ID获取所有的子级分类ID
* 注意返回值中不包括传递进来的父类ID
* @param [type] $data 分类数组
* @param [type] $pid 父类id
* @return [type] 子类id数组
*/
public function getChildsID($data, $pid) {
$arr =array(); foreach($data as $v) {
if($v[$this->parentName] == $pid) {
$arr[] = $v[$this->sonName];
$arr = array_merge($arr, self::getChildsID($data, $v[$this->sonName]));
}
} return $arr;
} /**
* 根据传递的子类ID获取所有的父类ID
* 注意返回值中不包括传递进来的子类ID
* @param [type] $data 分类数组
* @param [type] $id 子类id
* @return [type] 父类id数组
*/
public function getParentsID($data, $id) {
$arr = array(); foreach($data as $v) {
if($v[$this->sonName] == $id) {
$arr[] = $v[$this->parentName];
$arr = array_merge($arr, self::getParentsID($data, $v[$this->parentName]));
}
} return $arr;
} /**
* 获取结构化的数组
* @param $levelData 含有分级信息的数组
* @return array
*/
public function getTree($levelData)
{
// usort($leveData,array('Category','sortByLever'));
$leveDataReform = $this->reformArr($levelData);
$treeList = array();
foreach($leveDataReform as $data){
if($data['level']==1){//一级
$treeList[$data['id']] = $data;
}elseif($data['level']==2){//二级
$level2_parent_id[$data['id']] = $data['parent_id'];
$treeList[$data['parent_id']]['child'][$data['id']] = $data;
}elseif($data['level']==3){//三级
if(isset($level2_parent_id[$data['parent_id']])){
$treeList[$level2_parent_id[$data['parent_id']]]['child'][$data['parent_id']]['child'][$data['id']] = $data;
}
} }
return $treeList;
} function getDataTree($rows, $id='id',$pid = 'parent_id',$child = 'child',$root=0) {
$tree = array(); // 树
if(is_array($rows)){
$array = array();
foreach ($rows as $key=>$item){
$array[$item[$id]] =& $rows[$key];
}
foreach($rows as $key=>$item){
$parentId = $item[$pid];
if($root == $parentId){
$tree[] =&$rows[$key];
}else{
if(isset($array[$parentId])){
$parent =&$array[$parentId];
$parent[$child][]=&$rows[$key];
}
}
}
}
return $tree;
} /**
* @param array $arr
* @param string $field
* @return array
*/
public function reformArr($arr = array(array('id'=>1, 'other'=>''),), $field = 'id'){
$new_arr = array();
if (!is_array($arr)) {
return $new_arr;
}
foreach ($arr as $av) {
if (!is_array($av)) {
break;
}
if (!array_key_exists($field, $av)) {
break;
}
if (!isset($new_arr[$av[$field]])) {
$new_arr[$av[$field]] = $av;
}
}
return $new_arr;
} /**
* @param $a
* @param $b
* @return int
*/
public function sortByOrderID($a,$b)
{ if($a['order_id']==$b['order_id'])
{
return 0;
}else{
return $a['order_id']>$b['order_id']?1:-1;
}
} /**
* @param $a
* @param $b
* @return int
*/
public function sortByLever($a,$b)
{
if($a['level']==$b['level'])
{
return 0;
}else{
return $a['level']>$b['level']?1:-1;
}
} } require 'medoo.php';
require './TimerHelper.php';
$database = new medoo([
'database_type' => 'mysql',
'database_name' => 'test',
'server' => 'localhost',
'username' => 'root',
'password' => '',
'charset' => 'gbk'
]); $classify = $database->query("SELECT * FROM classify ORDER BY level ASC,orderid DESC,id asc LIMIT 100000")->fetchAll(); /*
$tree_data = [
['id'=>1,'parent_id'=>0,'name'=>'01','order_id'=>0],
['id'=>2,'parent_id'=>0,'name'=>'02','order_id'=>0],
['id'=>3,'parent_id'=>0,'name'=>'03','order_id'=>0],
['id'=>4,'parent_id'=>1,'name'=>'14','order_id'=>0],
['id'=>5,'parent_id'=>1,'name'=>'15','order_id'=>0],
['id'=>6,'parent_id'=>1,'name'=>'16','order_id'=>0],
['id'=>7,'parent_id'=>2,'name'=>'27','order_id'=>0],
['id'=>8,'parent_id'=>2,'name'=>'28','order_id'=>0],
['id'=>9,'parent_id'=>2,'name'=>'29','order_id'=>0],
['id'=>10,'parent_id'=>4,'name'=>'104','order_id'=>100],
['id'=>11,'parent_id'=>4,'name'=>'114','order_id'=>10000],
['id'=>12,'parent_id'=>4,'name'=>'124','order_id'=>10000],
['id'=>13,'parent_id'=>11,'name'=>'104','order_id'=>12],
['id'=>14,'parent_id'=>11,'name'=>'114','order_id'=>11],
['id'=>15,'parent_id'=>11,'name'=>'124','order_id'=>10],
];
*/ $cate = new Category('id','parent_id');
TimerHelper::start('1');
echo "";
//print_r($cate->unlimitedForLevel($tree_data,0,0)); $tree_data = $cate->getTree($classify); foreach($tree_data as $key=>$class){
echo $class['name']."";
if(isset($class['child']) && !empty($class['child'])){
foreach($class['child'] as $child1_class){
echo " ".$child1_class['name']."";
if(isset($child1_class['child']) && !empty($child1_class['child'])){
foreach($child1_class['child'] as $child2_class){
echo " ".$child2_class['name']."";
} }
}
}
} TimerHelper::stop('1'); /***** CREATE TABLE `classify` (
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`name` varchar(50) NOT NULL COMMENT '产品名称',
`admin_id` int(10) unsigned NOT NULL COMMENT '管理员id',
`parent_id` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '父级id',
`level` tinyint(4) unsigned NOT NULL DEFAULT '1' COMMENT '第几级',
`orderid` smallint(4) unsigned NOT NULL DEFAULT '999' COMMENT '排序',
`flag` tinyint(4) unsigned NOT NULL DEFAULT '1' COMMENT '是否隐藏',
`addtime` int(10) unsigned DEFAULT NULL,
PRIMARY KEY (`id`),
KEY `parent_id` (`parent_id`),
KEY `flag` (`flag`)
) ENGINE=InnoDB AUTO_INCREMENT=0 DEFAULT CHARSET=gbk; *****/
php分类树的更多相关文章
- C#无限极分类树-创建-排序-读取 用Asp.Net Core+EF实现之方法二:加入缓存机制
在上一篇文章中我用递归方法实现了管理菜单,在上一节我也提到要考虑用缓存,也算是学习一下.Net Core的缓存机制. 关于.Net Core的缓存,官方有三种实现: 1.In Memory Cachi ...
- C#无限极分类树-创建-排序-读取 用Asp.Net Core+EF实现
今天做一个管理后台菜单,想着要用无限极分类,记得园子里还是什么地方见过这种写法,可今天找了半天也没找到,没办法静下心来自己写了: 首先创建节点类(我给它取名:AdminUserTree): /// & ...
- ecshop显示所有分类树栏目
1.找到 category.php 和goods.php 两个文件修改: $smarty->assign('categories', get_categories_tree(0)); // 分类 ...
- 决策树算法原理(CART分类树)
决策树算法原理(ID3,C4.5) CART回归树 决策树的剪枝 在决策树算法原理(ID3,C4.5)中,提到C4.5的不足,比如模型是用较为复杂的熵来度量,使用了相对较为复杂的多叉树,只能处理分类不 ...
- OneThink生成分类树方法(list_to_tree)使用!
具体方法: Application / Common / Common / function.php 下的 224行: function list_to_tree($list, $pk='id', $ ...
- sklearn 学习之分类树
概要 基于 sklearn 包自带的 iris 数据集,了解一下分类树的各种参数设置以及代表的意义. iris 数据集介绍 iris 数据集包含 150 个样本,对应数据集的每行数据,每行数据包含 ...
- C#开发BIMFACE系列27 服务端API之获取模型数据12:获取构件分类树
系列目录 [已更新最新开发文章,点击查看详细] BIMFACE官方示例中,加载三维模型后,模型浏览器中左上角默认提供了“目录树”的功能,清晰地展示了模型的完整构成及上下级关系. 本篇介绍如何获 ...
- php 两种获取分类树的方法
php 两种获取分类树的方法 1. /** * 获取分类树 * @param array $array 数据源 * @param int $pid 父级ID * @param int $level 分 ...
- Sklearn分类树在合成数集上的表现
小伙伴们大家好~o( ̄▽ ̄)ブ,今天我们开始来看一下Sklearn分类树的表现,我的开发环境是Jupyter lab,所用的库和版本大家参考: Python 3.7.1(你的版本至少要3.4以上) S ...
- 机器学习实战---决策树CART简介及分类树实现
https://blog.csdn.net/weixin_43383558/article/details/84303339?utm_medium=distribute.pc_relevant_t0. ...
随机推荐
- input子系统分析(转)
转自:http://www.linuxidc.com/Linux/2011-09/43187.htm 作者:作者:YAOZHENGUO2006 Input子系统处理输入事务,任何输入设备的驱动程序都可 ...
- IOS设计模式浅析之建造者模式(Builder)
定义 "将一个复杂对象的构建与它的表现分离,使得同样的构建过程可以创建不同的表现". 最初的定义出现于<设计模式>(Addison-Wesley,1994). 看这个概 ...
- knockout+weui+zepto
主文件wxapp.ts 1>在ts中,建议继承componentui //操作菜单表 actionsheet showactionsheet { title 上拉菜单标题 btns 操作组 建议 ...
- LeetCode455. Assign Cookies
Description Assume you are an awesome parent and want to give your children some cookies. But, you s ...
- SparseArray具体解释,我说SparseArray,你说要!
可能在Android 中使用HashMap 的时候看到过提示. HashMap<Integer,Bitmap> mp = new HashMap<Integer,Bitmap> ...
- SHELL $RANDOM产生的随机数范围是0到32767
1.使用系统的 $RANDOM 变量 fdipzone@ubuntu:~$ echo $RANDOM 17617 fdipzone@ubuntu:~$ echo $RANDOM 17617 $RAND ...
- 视频采集接口camera link 在8148中的应用
(1)应用背景 (2)camera link 简介 (3)camera link 与8148 (4)camera link 应用实例 ---------------------author:pkf - ...
- 从头认识java-13.9 隐式和显示的创建类型实例
对于上一章节擦除引起的问题与解决的方法有读者提出过于简单.这里解释一下:由于笔者本身也遇不到对应的问题.仅仅是凭空想像一些有可能的问题,基于水平有限,因此上一章节写的比較简单,欢迎广大读者踊跃提意见, ...
- OpenCV学习笔记一:OpenCV概览与配置编译
一,OpenCV OpenCV官方网站:http://opencv.org/ OpenCV目前最新代码库地址:https://github.com/itseez/opencv 二,简介: OpenC ...
- 《从零开始学Swift》学习笔记(Day 33)——属性观察者
原创文章,欢迎转载.转载请注明:关东升的博客 为了监听属性的变化,Swift提供了属性观察者.属性观察者能够监听存储属性的变化,即便变化前后的值相同,它们也能监听到. 属性观察者主要有以下两个: l ...