当前位置: 首页 > 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注意&…...

【入坑系列】TiDB 强制索引在不同库下不生效问题

文章目录 背景SQL 优化情况线上SQL运行情况分析怀疑1:执行计划绑定问题?尝试:SHOW WARNINGS 查看警告探索 TiDB 的 USE_INDEX 写法Hint 不生效问题排查解决参考背景 项目中使用 TiDB 数据库,并对 SQL 进行优化了,添加了强制索引。 UAT 环境已经生效,但 PROD 环境强制索…...

Java如何权衡是使用无序的数组还是有序的数组

在 Java 中,选择有序数组还是无序数组取决于具体场景的性能需求与操作特点。以下是关键权衡因素及决策指南: ⚖️ 核心权衡维度 维度有序数组无序数组查询性能二分查找 O(log n) ✅线性扫描 O(n) ❌插入/删除需移位维护顺序 O(n) ❌直接操作尾部 O(1) ✅内存开销与无序数组相…...

无法与IP建立连接,未能下载VSCode服务器

如题&#xff0c;在远程连接服务器的时候突然遇到了这个提示。 查阅了一圈&#xff0c;发现是VSCode版本自动更新惹的祸&#xff01;&#xff01;&#xff01; 在VSCode的帮助->关于这里发现前几天VSCode自动更新了&#xff0c;我的版本号变成了1.100.3 才导致了远程连接出…...

Module Federation 和 Native Federation 的比较

前言 Module Federation 是 Webpack 5 引入的微前端架构方案&#xff0c;允许不同独立构建的应用在运行时动态共享模块。 Native Federation 是 Angular 官方基于 Module Federation 理念实现的专为 Angular 优化的微前端方案。 概念解析 Module Federation (模块联邦) Modul…...

2025盘古石杯决赛【手机取证】

前言 第三届盘古石杯国际电子数据取证大赛决赛 最后一题没有解出来&#xff0c;实在找不到&#xff0c;希望有大佬教一下我。 还有就会议时间&#xff0c;我感觉不是图片时间&#xff0c;因为在电脑看到是其他时间用老会议系统开的会。 手机取证 1、分析鸿蒙手机检材&#x…...

使用 Streamlit 构建支持主流大模型与 Ollama 的轻量级统一平台

🎯 使用 Streamlit 构建支持主流大模型与 Ollama 的轻量级统一平台 📌 项目背景 随着大语言模型(LLM)的广泛应用,开发者常面临多个挑战: 各大模型(OpenAI、Claude、Gemini、Ollama)接口风格不统一;缺乏一个统一平台进行模型调用与测试;本地模型 Ollama 的集成与前…...

Device Mapper 机制

Device Mapper 机制详解 Device Mapper&#xff08;简称 DM&#xff09;是 Linux 内核中的一套通用块设备映射框架&#xff0c;为 LVM、加密磁盘、RAID 等提供底层支持。本文将详细介绍 Device Mapper 的原理、实现、内核配置、常用工具、操作测试流程&#xff0c;并配以详细的…...

有限自动机到正规文法转换器v1.0

1 项目简介 这是一个功能强大的有限自动机&#xff08;Finite Automaton, FA&#xff09;到正规文法&#xff08;Regular Grammar&#xff09;转换器&#xff0c;它配备了一个直观且完整的图形用户界面&#xff0c;使用户能够轻松地进行操作和观察。该程序基于编译原理中的经典…...

Yolov8 目标检测蒸馏学习记录

yolov8系列模型蒸馏基本流程&#xff0c;代码下载&#xff1a;这里本人提交了一个demo:djdll/Yolov8_Distillation: Yolov8轻量化_蒸馏代码实现 在轻量化模型设计中&#xff0c;**知识蒸馏&#xff08;Knowledge Distillation&#xff09;**被广泛应用&#xff0c;作为提升模型…...

推荐 github 项目:GeminiImageApp(图片生成方向,可以做一定的素材)

推荐 github 项目:GeminiImageApp(图片生成方向&#xff0c;可以做一定的素材) 这个项目能干嘛? 使用 gemini 2.0 的 api 和 google 其他的 api 来做衍生处理 简化和优化了文生图和图生图的行为(我的最主要) 并且有一些目标检测和切割(我用不到) 视频和 imagefx 因为没 a…...