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. ...
随机推荐
- zabbix 监控如下内容
我们使用zabbix做了如下的监控: 1.硬件监控. 通过SNMP来进行路由器交换机的监控(这些可以跟一些厂商沟通来了解如何做). 服务器的温度以及其他,可以通过IPMI来实现.当然如果没有硬件全都是 ...
- 前端webview开发中遇到的一些问题及其解决方法
最近做了一个webview中的兑换页面,本来以为很简单,想不到遇到了远远超出预期数量的BUG,记下来,以备后患. 1 inline-block元素折行 BUG描述:现在我有三个DIV,要在一列等宽排列 ...
- [PHP开发必备] -- 小巧强悍的MYSQL-Front中文版使用教程,附最新版下载地址
PHP开发已经各位工程师轻车熟路的事情,MySQL也是经常都要用的产品,能有一个简单而又强大的管理工具,那可是咱们PHP开发工程师的福气. 下面浪风小园子就为大家介绍下来自国外小巧的MySQL管理工具 ...
- Eclipse 工作空间(Workspace)
Eclipse 工作空间(Workspace) eclipse 工作空间包含以下资源: 项目 文件 文件夹 项目启动时一般可以设置工作空间,你可以将其设置为默认工作空间,下次启动后无需再配置: 工作空 ...
- What is special about /dev/tty?
ls -la /dev/tty shows the output: crw-rw-rw- 1 root tty 5, 0 Dec 14 22:21 /dev/tty The 'c' means it' ...
- java FTP 上传下载删除文件
在JAVA程序中,经常需要和FTP打交道,比如向FTP服务器上传文件.下载文件,本文简单介绍如何利用jakarta commons中的FTPClient(在commons-net包中)实现上传下载文件 ...
- day6笔记
一.上节回顾 list:li = [1,2,3,5,'a']增加:append:末尾加入==追加 insert:插入,在任意位置,insert(index,'内容') extend:迭代着加入,'as ...
- Linux学习目录
一.CentOS for Linux 大神博客:骏马金龙 Linux也可以参考,这篇博客进行学习 http://www.cnblogs.com/f-ck-need-u/p/7048359.html ...
- SVG 与 Canvas:如何选择
SVG 与 Canvas:如何选择 61(共 69)对本文的评价是有帮助 - 评价此主题 本主题一开始将对 SVG 与 Canvas 进行简要比较,接下来会讨论大量的比较代码示例,如光线跟踪和绿屏 ...
- 【穿插】Python基础之文件、文件夹的创建,对上一期代码进行优化
在上一期妹子图的爬虫教程中,我们将图片都保存在了代码当前目录下,这样并不便于浏览,我们应该将同一个模特的图片都放在一个文件夹中. 今天我们就简单讲一下Python下如何创建文件.文件夹,今后就可以用上 ...