一、需要变形的二维数组

 $arr = Array(
Array
(
'material_id' => 1,
'material_name' => '铜板纸',
'parent_id' => 0
),
Array
(
'material_id' => 26,
'material_name' => '哑粉纸',
'parent_id' => 0
),
Array
(
'material_id' => 61,
'material_name' => '胶版',
'parent_id' => 0
),
Array
(
'material_id' => 95,
'material_name' => '高级哑粉',
'parent_id' => 0
),
Array
(
'material_id' => 4,
'material_name' => '250g铜版纸',
'parent_id' => 1
),
Array
(
'material_id' => 5,
'material_name' => '200g铜版纸',
'parent_id' => 1
),
Array
(
'material_id' => 27,
'material_name' => '250g哑粉纸',
'parent_id' => 26
), Array
(
'material_id' => 28,
'material_name' => '200g哑粉纸',
'parent_id' => 26
),
Array
(
'material_id' => 29,
'material_name' => '200g哑粉纸的子项',
'parent_id' => 28
),
Array
(
'material_id' => 30,
'material_name' => '200g哑粉纸的子项的子项',
'parent_id' => 29
)
);

二、变形后的数组形式

 array (
0 =>
array (
'material_id' => 1,
'material_name' => '铜板纸',
'parent_id' => 0,
'children' =>
array (
0 =>
array (
'material_id' => 4,
'material_name' => '250g铜版纸',
'parent_id' => 1,
),
1 =>
array (
'material_id' => 5,
'material_name' => '200g铜版纸',
'parent_id' => 1,
),
),
),
1 =>
array (
'material_id' => 26,
'material_name' => '哑粉纸',
'parent_id' => 0,
'children' =>
array (
0 =>
array (
'material_id' => 27,
'material_name' => '250g哑粉纸',
'parent_id' => 26,
),
1 =>
array (
'material_id' => 28,
'material_name' => '200g哑粉纸',
'parent_id' => 26,
'children' =>
array (
0 =>
array (
'material_id' => 29,
'material_name' => '200g哑粉纸的子项',
'parent_id' => 28,
'children' =>
array (
0 =>
array (
'material_id' => 30,
'material_name' => '200g哑粉纸的子项的子项',
'parent_id' => 29,
),
),
),
),
),
),
),
2 =>
array (
'material_id' => 61,
'material_name' => '胶版',
'parent_id' => 0,
),
3 =>
array (
'material_id' => 95,
'material_name' => '高级哑粉',
'parent_id' => 0,
),
)

 三、实现代码

     public function ceshi($arr, &$arrParent = [])
{
// 首次获取parent_id = 0的相关父级项
foreach ($arr as $key => $val) {
if ($val['parent_id'] == 0) {
$arrParent[] = $val;
unset($arr[$key]);
}
} foreach ($arrParent as $parentKey => $parent) {
foreach ($arr as $key => $val) {
if ($val['parent_id'] == $parent['material_id']) {
$arrParent[$parentKey]['children'][] = $val;
unset($arr[$key]); // 匹配完成则删除
$this->ceshi($arr, $arrParent[$parentKey]['children']);
}
}
} return $arrParent;
}

PHP针对二维数组无限遍历变形研究的更多相关文章

  1. 元素均匀排列自动换行&二维数组前端遍历

    1.元素均匀排列并自动换行 display:flex; flex-wrap:wrap; 2.getFiled();取一行,取多行的话用getFiled(‘id’,true); 3.二维数组前端遍历: ...

  2. C++ 性能小测 1 二维数组的遍历效率

    C++ 性能小测 1 二维数组的遍历效率 遍历二维数组时,常规思路是使用一个嵌套循环.一方面,由于 CPU 使用了分支预测技术,因此通常将循环次数最多循环的放在最内层.另一方面,由于二维数组是按行存储 ...

  3. 二维数组初始化 遍历 动态赋值 内存图 Day08

    package com.sxt.arraytest3; /* * 二维数组 */ public class TestArray { public static void main(String[] a ...

  4. Openjudge-NOI题库-二维数组回形遍历

    题目描述 Description 给定一个row行col列的整数数组array,要求从array[0][0]元素开始,按回形从外向内顺时针顺序遍历整个数组.如图所示:  输入输出格式 Input/ou ...

  5. vector 定义的二维数组的遍历

    之前我们分享了STL的一些容器,再介绍vector中只介绍了二维的vector的定义并没有说二维的vector怎么遍历,那么我们今天就来看下二维的vector怎么遍历 看下面的代码吧. #includ ...

  6. c#中对txt文件的读取与写入,针对二维数组

    class Program { ; ; static string[,] str = new string[ROW, COL]; static void Main(string[] args) { R ...

  7. 二维数组针对某字段排序 - array_multisort()

    /** * 针对二维数组下的某字段排序 * @param array $myarr 被排序数组 * @param string $sort_key 排序根据字段 * @param flag $sort ...

  8. 什么是二维数组?二维遍历?Java二维数组制作图片迷宫 使用如鹏游戏引擎制作窗口界面 附带压缩包下载,解压后双击start.bat启动

    什么是二维数组? 数组当中放的还是数组 int [][] arr=new int[3][2]; 有3个小箱子,每个箱子2个格子. 看结果? int [][] arr=new int[3][2]; Sy ...

  9. 《java入门第一季》二维数组三个案例详解

    案例一:遍历二维数组 /* 需求:二维数组遍历 外循环控制的是二维数组的长度,其实就是一维数组的个数行数. 内循环控制的是一维数组的长度,每一行,一维数组元素分别的个数. */ class Array ...

随机推荐

  1. Linux命令总结_sort排序命令

    1.sort命令是帮我们依据不同的数据类型进行排序,其语法及常用参数格式: sort [-bcfMnrtk][源文件][-o 输出文件]       补充说明:sort可针对文本文件的内容,以行为单位 ...

  2. EIP权限工作流升级说明-2019/5/23

    增加mysql版本在线预览地址:http://www.eipflow.com:3000/

  3. jmeter压力测试报告

    XXX压力测试报告 时间:2015-08-04                                             测试人员:xxx 目录 XXX压力测试报告... 1 一  测试 ...

  4. Js获取当前的日期和时间以及时间戳转化为时间

    /** *获取当前时间 *format=1精确到天 *format=2精确到分 */ function getCurrentDate(format) { var now = new Date(); v ...

  5. python列表逆序三种方法

    栗子: # 题目:将一个数组逆序输出. # # 程序分析:用第一个与最后一个交换. import random list =[random.randint(0,100) for _ in range( ...

  6. 在VMware上克隆Linux虚拟机及其网卡配置方法

    最近在搭建Hadoop集群,1个Master,3个Workers.使用VMware workstations创建Linux虚拟机,版本是CentOS7.安装完成并做了相应的网络配置后,使用VMware ...

  7. 社交系统ThinkSNS+在研发过程中,如何做到 Laravel 配置可以网站后台配置

    什么是ThinkSNS+ ThinkSNS(简称TS),一款全平台综合性社交系统,为国内外大中小企业和创业者提供社会化软件研发及技术解决方案. 本文分享下利用 Laravel 的 Bootstrapp ...

  8. C 语言实例 - 阶乘

    C 语言实例 - 阶乘 一个正整数的阶乘(英语:factorial)是所有小于及等于该数的正整数的积,并且0的阶乘为1.自然数n的阶乘写作n!. n!=×××...×n.阶乘亦可以递归方式定义:!=, ...

  9. 使用JSONPath

    SONPath是查询JSON对象元素的标准方法.JSONPath使用路径表达式来导航JSON文档中的元素,嵌套元素和数组.有关JSON的更多信息,请参阅JSON简介. 使用JSONPath访问JSON ...

  10. Linux基本系统优化

    Linux基本系统优化  Linux Linux的网络功能相当强悍,一时之间我们无法了解所有的网络命令, 在配置服务器基础环境时,先了解下网络参数设定命令. ifconfig 查询.设置网卡和ip等参 ...