当前位置: 首页 > news >正文

PHP 使用递归方式 将其二维数组整合为层级树 其中层级id 为一个uuid的格式 造成的诡异问题 已解决

不啰嗦  直接上源代码

<?php
function findChildren($list, $p_id){$r = array();foreach ($list as $k => $item) {if ($item['fid'] == $p_id) {unset($list[$k]);$length = count($r);$r[$length] = $item;if ($t = findChildren($list, $item['id'])) {$r[$length]['children'] = $t;}}}return $r;
}function findChildren2($list,$p_id,&$sike=[]) {$r = array();foreach($list as $k=>$item) {if($item['fid']==$p_id && !in_array($item['id'],$sike)) {$menu = $item;array_push($sike,$item['id']);$children = findChildren2($list,$item['id'],$sike);if(!empty($children)) {$menu['children'] = $children;}	$r[] = $menu;}}return $r;
}$node_list  = [["text"=>"首页","id"=>'1',"fid"=>"0"],["text"=>"基础信息管理","id"=>'2',"fid"=>"0"],["text"=>"站点信息","id"=>'3',"fid"=>'2'],["text"=>"线路信息","id"=>'4',"fid"=>'2'],
];$node_list1  = [["text"=>"首页","id"=>'2bd6db1b-4971-8a89-b2b7-e729ddb78ffa',"fid"=>"0"],["text"=>"基础信息管理","id"=>'376adc62-5414-a36d-eb49-65ae7c7a91b0',"fid"=>"0"],["text"=>"站点信息","id"=>'8ef4a669-68c0-48f7-5078-1d2a487ff901',"fid"=>'376adc62-5414-a36d-eb49-65ae7c7a91b0'],["text"=>"线路信息","id"=>'7b4a1c42-ec66-3fb5-3266-3686d2466bc9',"fid"=>'376adc62-5414-a36d-eb49-65ae7c7a91b0'],
];$node_list2  = [["text"=>"首页","id"=>'2bd6db1b-4971-8a89-b2b7-e729ddb78ffa',"fid"=>"0"],["text"=>"基础信息管理","id"=>'b655b684-e112-5908-a522-f4f96728edb0',"fid"=>"0"],["text"=>"站点信息","id"=>'8ef4a669-68c0-48f7-5078-1d2a487ff901',"fid"=>'b655b684-e112-5908-a522-f4f96728edb0'],["text"=>"线路信息","id"=>'7b4a1c42-ec66-3fb5-3266-3686d2466bc9',"fid"=>'b655b684-e112-5908-a522-f4f96728edb0'],
];$menus_list = findChildren($node_list, 0);
$sike = [];
$menus_list2 = findChildren2($node_list, 0,$sike);
echo "----------------------------------------->>结果1<<------------------------------------".PHP_EOL;
var_dump($menus_list);
echo "----------------------------------------->>结果2<<------------------------------------".PHP_EOL;
var_dump($menus_list2);echo "正常的uuid格式的层级".PHP_EOL;	
$menus_list3 = findChildren($node_list1, 0);
$sike1 = [];
$menus_list4 = findChildren2($node_list1, 0,$sike1);
echo "----------------------------------------->>结果3<<------------------------------------".PHP_EOL;
var_dump($menus_list3);
echo "----------------------------------------->>结果4<<------------------------------------".PHP_EOL;
var_dump($menus_list4);echo "不正常的uuid格式的层级".PHP_EOL;
$menus_list5 = findChildren($node_list2, 0);
$sike2 = [];
$menus_list6 = findChildren2($node_list2, 0,$sike2);
echo "----------------------------------------->>结果5<<------------------------------------".PHP_EOL;
var_dump($menus_list5);
echo "----------------------------------------->>结果6<<------------------------------------".PHP_EOL;
var_dump($menus_list6);

结果输出:

----------------------------------------->>结果1<<------------------------------------
array(2) {[0]=>array(3) {["text"]=>string(6) "首页"["id"]=>string(1) "1"["fid"]=>string(1) "0"}[1]=>array(4) {["text"]=>string(18) "基础信息管理"["id"]=>string(1) "2"["fid"]=>string(1) "0"["children"]=>array(2) {[0]=>array(3) {["text"]=>string(12) "站点信息"["id"]=>string(1) "3"["fid"]=>string(1) "2"}[1]=>array(3) {["text"]=>string(12) "线路信息"["id"]=>string(1) "4"["fid"]=>string(1) "2"}}}
}
----------------------------------------->>结果2<<------------------------------------
array(2) {[0]=>array(3) {["text"]=>string(6) "首页"["id"]=>string(1) "1"["fid"]=>string(1) "0"}[1]=>array(4) {["text"]=>string(18) "基础信息管理"["id"]=>string(1) "2"["fid"]=>string(1) "0"["children"]=>array(2) {[0]=>array(3) {["text"]=>string(12) "站点信息"["id"]=>string(1) "3"["fid"]=>string(1) "2"}[1]=>array(3) {["text"]=>string(12) "线路信息"["id"]=>string(1) "4"["fid"]=>string(1) "2"}}}
}
正常的uuid格式的层级
----------------------------------------->>结果3<<------------------------------------
array(2) {[0]=>array(3) {["text"]=>string(6) "首页"["id"]=>string(36) "2bd6db1b-4971-8a89-b2b7-e729ddb78ffa"["fid"]=>string(1) "0"}[1]=>array(4) {["text"]=>string(18) "基础信息管理"["id"]=>string(36) "376adc62-5414-a36d-eb49-65ae7c7a91b0"["fid"]=>string(1) "0"["children"]=>array(2) {[0]=>array(3) {["text"]=>string(12) "站点信息"["id"]=>string(36) "8ef4a669-68c0-48f7-5078-1d2a487ff901"["fid"]=>string(36) "376adc62-5414-a36d-eb49-65ae7c7a91b0"}[1]=>array(3) {["text"]=>string(12) "线路信息"["id"]=>string(36) "7b4a1c42-ec66-3fb5-3266-3686d2466bc9"["fid"]=>string(36) "376adc62-5414-a36d-eb49-65ae7c7a91b0"}}}
}
----------------------------------------->>结果4<<------------------------------------
array(2) {[0]=>array(3) {["text"]=>string(6) "首页"["id"]=>string(36) "2bd6db1b-4971-8a89-b2b7-e729ddb78ffa"["fid"]=>string(1) "0"}[1]=>array(4) {["text"]=>string(18) "基础信息管理"["id"]=>string(36) "376adc62-5414-a36d-eb49-65ae7c7a91b0"["fid"]=>string(1) "0"["children"]=>array(2) {[0]=>array(3) {["text"]=>string(12) "站点信息"["id"]=>string(36) "8ef4a669-68c0-48f7-5078-1d2a487ff901"["fid"]=>string(36) "376adc62-5414-a36d-eb49-65ae7c7a91b0"}[1]=>array(3) {["text"]=>string(12) "线路信息"["id"]=>string(36) "7b4a1c42-ec66-3fb5-3266-3686d2466bc9"["fid"]=>string(36) "376adc62-5414-a36d-eb49-65ae7c7a91b0"}}}
}
不正常的uuid格式的层级
----------------------------------------->>结果5<<------------------------------------
array(4) {[0]=>array(3) {["text"]=>string(6) "首页"["id"]=>string(36) "2bd6db1b-4971-8a89-b2b7-e729ddb78ffa"["fid"]=>string(1) "0"}[1]=>array(4) {["text"]=>string(18) "基础信息管理"["id"]=>string(36) "b655b684-e112-5908-a522-f4f96728edb0"["fid"]=>string(1) "0"["children"]=>array(2) {[0]=>array(3) {["text"]=>string(12) "站点信息"["id"]=>string(36) "8ef4a669-68c0-48f7-5078-1d2a487ff901"["fid"]=>string(36) "b655b684-e112-5908-a522-f4f96728edb0"}[1]=>array(3) {["text"]=>string(12) "线路信息"["id"]=>string(36) "7b4a1c42-ec66-3fb5-3266-3686d2466bc9"["fid"]=>string(36) "b655b684-e112-5908-a522-f4f96728edb0"}}}[2]=>array(3) {["text"]=>string(12) "站点信息"["id"]=>string(36) "8ef4a669-68c0-48f7-5078-1d2a487ff901"["fid"]=>string(36) "b655b684-e112-5908-a522-f4f96728edb0"}[3]=>array(3) {["text"]=>string(12) "线路信息"["id"]=>string(36) "7b4a1c42-ec66-3fb5-3266-3686d2466bc9"["fid"]=>string(36) "b655b684-e112-5908-a522-f4f96728edb0"}
}
----------------------------------------->>结果6<<------------------------------------
array(2) {[0]=>array(3) {["text"]=>string(6) "首页"["id"]=>string(36) "2bd6db1b-4971-8a89-b2b7-e729ddb78ffa"["fid"]=>string(1) "0"}[1]=>array(4) {["text"]=>string(18) "基础信息管理"["id"]=>string(36) "b655b684-e112-5908-a522-f4f96728edb0"["fid"]=>string(1) "0"["children"]=>array(2) {[0]=>array(3) {["text"]=>string(12) "站点信息"["id"]=>string(36) "8ef4a669-68c0-48f7-5078-1d2a487ff901"["fid"]=>string(36) "b655b684-e112-5908-a522-f4f96728edb0"}[1]=>array(3) {["text"]=>string(12) "线路信息"["id"]=>string(36) "7b4a1c42-ec66-3fb5-3266-3686d2466bc9"["fid"]=>string(36) "b655b684-e112-5908-a522-f4f96728edb0"}}}
}

结果5 出现了一个诡异的效果  也就是子级也跑到和父级一个层级了  这显然不是我们想要的结果

findChildren2 是我为了避免结果5 这种情况而进行改造了   

下面是chatGPT 给出的说明

最终结果   修改   使用strcmp 

function findChildren($list, $p_id){$r = array();foreach ($list as $k => $item) {//if ($item['fid'] == $p_id) {if (strcmp($item['fid'], $p_id) ===0 )  {unset($list[$k]);$length = count($r);$r[$length] = $item;if ($t = findChildren($list, $item['id'])) {$r[$length]['children'] = $t;}}}return $r;
}function findChildren2($list,$p_id,&$sike=[]) {$r = array();foreach($list as $k=>$item) {//if($item['fid']==$p_id && !isset($sike[$item['id']])) {if (strcmp($item['fid'], $p_id) ===0 )  {$menu = $item;//$sike[$item['id']] = true;$children = findChildren2($list,$item['id'],$sike);if(!empty($children)) {$menu['children'] = $children;}$r[] = $menu;}}return $r;
}

使用该逻辑判断 :if (strcmp($item['fid'], $p_id) === 0) {}

完美解决!!!!!

相关文章:

PHP 使用递归方式 将其二维数组整合为层级树 其中层级id 为一个uuid的格式 造成的诡异问题 已解决

不啰嗦 直接上源代码 <?php function findChildren($list, $p_id){$r array();foreach ($list as $k > $item) {if ($item[fid] $p_id) {unset($list[$k]);$length count($r);$r[$length] $item;if ($t findChildren($list, $item[id])) {$r[$length][children] …...

rv1126-rv1109-添加分区,定制固件,开机挂载功能

===================================================================== 修改分区: 这里是分区的txt文件选择; 这里是分区的划分,我这里回车了,方便看 FIRMWARE_VER: 8.1 MACHINE_MODEL: RV1126 MACHINE_ID: 007 MANUFACTURER: RV1126 MAGIC: 0x5041524B ATAG: 0x00200…...

一台电脑使用多个gitee账号,以及提交忽略部分文件

目录 ​编辑 一&#xff1a;前言 二&#xff1a;解决方法 三&#xff1a;提交gitee时忽略文件 一&#xff1a;前言 在开发中&#xff0c;我们拥有不止一个 gitee 账号&#xff0c;通常而言一个是公司的&#xff0c;一个是私人的。有时候我们在公司写了一些自己的东西&#…...

解析邮件文本内容; Mime文本解析; MimeStreamParser; multipart解析

原始文本 ------_Part_46705_715015081.1699589700255 Content-Type: text/html;charsetUTF-8 Content-Transfer-Encoding: base64PGh0bWwCiAgICA8aGVhZD4KICAgICAgICA8bWV0YSBodHRwLW VxdWl2PSJDb250ZW50LVR5cGUiIGNvbnRlbnQ9InRleHQvaHRt bDsgY2hhcnNldD1VVEYtOCICiAgICAgIC…...

获取请求IP以及IP解析成省份

某些业务需要获取请求IP以及将IP解析成省份之类的&#xff0c;于是我写了一个工具类&#xff0c;可以直接COPY /*** IP工具类* author xxl* since 2023/11/9*/ Slf4j public class IPUtils {/*** 过滤本地地址*/public static final String LOCAL_ADDRESS "127.0.0.1&quo…...

YOLOv8-seg改进:复现HIC-YOLOv5,HIC-YOLOv8-seg助力小目标分割

🚀🚀🚀本文改进:HIC-YOLOv8-seg:1)添加一个针对小物体的额外预测头,以提供更高分辨率的特征图2)在backbone和neck之间采用involution block来增加特征图的通道信息;3)在主干网末端加入 CBAM 的注意力机制; 🚀🚀🚀HIC-YOLOv8-seg小目标分割检测&复杂场景…...

vscode 终端进程启动失败: shell 可执行文件“C:\Windows\System32\WindowsPower

vscode 终端进程启动失败: shell 可执行文件“C:\Windows\System32\WindowsPower 第一次用vscode&#xff0c;然后遇到这个问题&#xff0c;在设置里搜索 terminal.integrated.defaultProfile.windows 将这里的null改成"Command Prompt" 重启就可以了...

【中间件篇-Redis缓存数据库02】Redis高级特性和应用(慢查询、Pipeline、事务、Lua)

Redis高级特性和应用(慢查询、Pipeline、事务、Lua) Redis的慢查询 许多存储系统&#xff08;例如 MySQL)提供慢查询日志帮助开发和运维人员定位系统存在的慢操作。所谓慢查询日志就是系统在命令执行前后计算每条命令的执行时间&#xff0c;当超过预设阀值,就将这条命令的相关…...

栈 和 队列

什么是栈? 一种特殊的线性表&#xff0c;只允许在固定的一端进行插入和删除元素操作。进行数据插入和删除操作的一端称为栈顶&#xff0c;另一端称为栈底。栈中的数据元素遵守后进先出&#xff08;LIFO - Last In First Out&#xff09;的原则。   从数据结构的角度来看&…...

【推荐】一款AI写作大师、问答、绘画工具-「智元兔 AI」

在当今技术飞速发展的时代&#xff0c;越来越多的领域开始应用人工智能&#xff08;Artificial Intelligence&#xff0c;简称AI&#xff09;。其中&#xff0c;AI写作工具备受瞩目&#xff0c;备受推崇。在众多的选择中&#xff0c;智元兔AI是一款在笔者使用过程中非常有帮助的…...

阿里云付费用户破100万 用户规模亚洲最大

导读阿里巴巴集团公布2018财年第一季度财报&#xff0c;阿里云达到一个重要里程碑&#xff0c;云计算付费用户数量首次超过100万&#xff0c;成为亚洲首家达到百万级用户规模的云计算公司。同时&#xff0c;企业级市场被云计算人工智能等新技术全面激活&#xff0c;推动该季度营…...

人工智能基础——Python:Matplotlib与绘图设计

人工智能的学习之路非常漫长&#xff0c;不少人因为学习路线不对或者学习内容不够专业而举步难行。不过别担心&#xff0c;我为大家整理了一份600多G的学习资源&#xff0c;基本上涵盖了人工智能学习的所有内容。点击下方链接,0元进群领取学习资源,让你的学习之路更加顺畅!记得…...

Ubuntu 配置 Github 的 SSH keys

先进入已有的 Git 目录或使用新建的一个 Git 仓库下。 设置 Github 用户名和邮箱&#xff1a; $ git config --global user.name [Github用户名] $ git config --global user.email [Github认证邮箱]生成 SSH 密钥文件&#xff1a; $ ssh-keygen -t rsa -C [Github认证邮箱]…...

Flink—— Flink Data transformation(转换)

Flink数据算子转换有很多类型&#xff0c;各位看官看好&#xff0c;接下来&#xff0c;演示其中的十八种类型。 1.Map&#xff08;映射转换&#xff09; DataStream → DataStream 将函数作用在集合中的每一个元素上,并返回作用后的结果&#xff0c;其中输入是一个数据流&…...

前端读取文件当文件选择相同文件名的文件,内容不会变化

前端读取文件当文件选择相同文件名的文件&#xff0c;内容不会变化 今天遇到个奇怪的bug&#xff0c;使用打开文件&#xff0c;并选择文件时&#xff0c;正常情况会读取文件信息。 但是如果先选择相同的文件名&#xff0c;则内容不会发生变化。 先说结论 只要不使用事件中e…...

PHP 服装销售管理系统mysql数据库web结构layUI布局apache计算机软件工程网页wamp

一、源码特点 PHP 服装销售管理系统是一套完善的web设计系统mysql数据库 &#xff0c;对理解php编程开发语言有帮助&#xff0c;系统具有完整的源代码和数据库&#xff0c;系统主要采用B/S模式开发。 php服装销售管理系统1 二、功能介绍 (1)员工管理&#xff1a;对员工信息…...

用于图像处理的高斯滤波器 (LoG) 拉普拉斯

一、说明 欢迎来到拉普拉斯和高斯滤波器的拉普拉斯的故事。LoG是先进行高斯处理&#xff0c;继而进行拉普拉斯算子的图像处理算法。用拉普拉斯具有过零功能&#xff0c;实现边缘岭脊提取。 二、LoG算法简述 在这篇博客中&#xff0c;让我们看看拉普拉斯滤波器和高斯滤波器的拉普…...

【h5 uniapp】 滚动 滚动条,数据跟着变化

uniapp项目 需求&#xff1a; 向下滑动时&#xff0c;数据增加&#xff0c;上方的日历标题日期也跟着变化 向上滑动时&#xff0c;上方的日历标题日期跟着变化 实现思路&#xff1a; 初次加载目前月份的数据 以及下个月的数据 this.getdate()触底加载 下个月份的数据 onReach…...

ModStartBlog v8.5.0 评论开关布局调整,系统后台全面优化

ModStart 是一个基于 Laravel 模块化极速开发框架。模块市场拥有丰富的功能应用&#xff0c;支持后台一键快速安装&#xff0c;让开发者能快的实现业务功能开发。 系统完全开源&#xff0c;基于 Apache 2.0 开源协议。 功能特性 丰富的模块市场&#xff0c;后台一键快速安装 …...

django|报错SQLite 3.8.3 or later is required的解决方案

迁移原同事写的程序&#xff0c;到新服务器上边。运行报错。解决方案有三种 降低django版本升级sqlite3&#xff0c;不低于3.8.3版本修改django源码 方案一、降低django版本 卸载高版本django pip uninstall django安装低版本&#xff0c;如 pip install django2.1.7注意&…...

eNSP-Cloud(实现本地电脑与eNSP内设备之间通信)

说明&#xff1a; 想象一下&#xff0c;你正在用eNSP搭建一个虚拟的网络世界&#xff0c;里面有虚拟的路由器、交换机、电脑&#xff08;PC&#xff09;等等。这些设备都在你的电脑里面“运行”&#xff0c;它们之间可以互相通信&#xff0c;就像一个封闭的小王国。 但是&#…...

[2025CVPR]DeepVideo-R1:基于难度感知回归GRPO的视频强化微调框架详解

突破视频大语言模型推理瓶颈,在多个视频基准上实现SOTA性能 一、核心问题与创新亮点 1.1 GRPO在视频任务中的两大挑战 ​安全措施依赖问题​ GRPO使用min和clip函数限制策略更新幅度,导致: 梯度抑制:当新旧策略差异过大时梯度消失收敛困难:策略无法充分优化# 传统GRPO的梯…...

K8S认证|CKS题库+答案| 11. AppArmor

目录 11. AppArmor 免费获取并激活 CKA_v1.31_模拟系统 题目 开始操作&#xff1a; 1&#xff09;、切换集群 2&#xff09;、切换节点 3&#xff09;、切换到 apparmor 的目录 4&#xff09;、执行 apparmor 策略模块 5&#xff09;、修改 pod 文件 6&#xff09;、…...

黑马Mybatis

Mybatis 表现层&#xff1a;页面展示 业务层&#xff1a;逻辑处理 持久层&#xff1a;持久数据化保存 在这里插入图片描述 Mybatis快速入门 ![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/6501c2109c4442118ceb6014725e48e4.png //logback.xml <?xml ver…...

SciencePlots——绘制论文中的图片

文章目录 安装一、风格二、1 资源 安装 # 安装最新版 pip install githttps://github.com/garrettj403/SciencePlots.git# 安装稳定版 pip install SciencePlots一、风格 简单好用的深度学习论文绘图专用工具包–Science Plot 二、 1 资源 论文绘图神器来了&#xff1a;一行…...

【HarmonyOS 5.0】DevEco Testing:鸿蒙应用质量保障的终极武器

——全方位测试解决方案与代码实战 一、工具定位与核心能力 DevEco Testing是HarmonyOS官方推出的​​一体化测试平台​​&#xff0c;覆盖应用全生命周期测试需求&#xff0c;主要提供五大核心能力&#xff1a; ​​测试类型​​​​检测目标​​​​关键指标​​功能体验基…...

测试markdown--肇兴

day1&#xff1a; 1、去程&#xff1a;7:04 --11:32高铁 高铁右转上售票大厅2楼&#xff0c;穿过候车厅下一楼&#xff0c;上大巴车 &#xffe5;10/人 **2、到达&#xff1a;**12点多到达寨子&#xff0c;买门票&#xff0c;美团/抖音&#xff1a;&#xffe5;78人 3、中饭&a…...

【C语言练习】080. 使用C语言实现简单的数据库操作

080. 使用C语言实现简单的数据库操作 080. 使用C语言实现简单的数据库操作使用原生APIODBC接口第三方库ORM框架文件模拟1. 安装SQLite2. 示例代码:使用SQLite创建数据库、表和插入数据3. 编译和运行4. 示例运行输出:5. 注意事项6. 总结080. 使用C语言实现简单的数据库操作 在…...

【python异步多线程】异步多线程爬虫代码示例

claude生成的python多线程、异步代码示例&#xff0c;模拟20个网页的爬取&#xff0c;每个网页假设要0.5-2秒完成。 代码 Python多线程爬虫教程 核心概念 多线程&#xff1a;允许程序同时执行多个任务&#xff0c;提高IO密集型任务&#xff08;如网络请求&#xff09;的效率…...

多模态大语言模型arxiv论文略读(108)

CROME: Cross-Modal Adapters for Efficient Multimodal LLM ➡️ 论文标题&#xff1a;CROME: Cross-Modal Adapters for Efficient Multimodal LLM ➡️ 论文作者&#xff1a;Sayna Ebrahimi, Sercan O. Arik, Tejas Nama, Tomas Pfister ➡️ 研究机构: Google Cloud AI Re…...