基于键值将平面php数组转换为多维数组?

时间:2010-05-11 19:12:14

标签: php arrays multidimensional-array

我有一个平面阵列,我正在尝试制作多维。基本上,我想找到拥有父项的项目,并为该父项ID创建一个子数组。现在(这是简化的),它看起来像这样:

Array 
(
  [0] => stdClass Object
  (
    [id] => 1
    [parent] => 0
    [name ] => Parent1
  )

  [1] => stdClass Object
  (
    [id] => 7
    [parent] => 1
    [name] => Child1
  )

  [2] => stdClass Object
  (
    [id] => 9
    [parent] => 1
    [name] => Child2
  )

  [3] => stdClass Object
  (
    [id] => 2
    [parent] => 0
    [name ] => Parent2
  )

  [4] => stdClass Object
  (
    [id] => 88
    [parent] => 2
    [name] => Childof2
  )
)

我正在努力做到这一点:

Array 
(
  [0] => stdClass Object
  (
    [id] => 1
    [parent] => 0
    [name ] => Parent1
    [children] => stdClass Object
    (
       [1] => stdClass Object
       (
         [id] => 7
         [parent] => 1
         [name] => Child1
       )

       [2] => stdClass Object
       (
          [id] => 9
          [parent] => 1
          [name] => Child2
       )
    )
  )

  [1] => stdClass Object
  (
    [id] => 2
    [parent] => 0
    [name ] => Parent2
    [children] => stdClass Object
    (
       [0] => stdClass Object
       (
         [id] => 88
         [parent] => 2
         [name] => Childof2
        )
    )
  )
)

2 个答案:

答案 0 :(得分:0)

使用递归的肮脏和缓慢的方式就在这里。伪代码:

$objects;// Your plain list.
$root = (object) array('id' => 0);

appendChildren($root, $objects);

function appendChildren(&$node, $objects)
{
    foreach($objects as $obj)
    {
        if($obj->parent == $node->id)
        {
            if(!isset($node->children))
                $node->children = array();

            $node->children[] = $obj;
            appendChildren($obj, $objects);
        }
    }
}

答案 1 :(得分:0)

<?php

/**
 * This function should be efficient for large sets.
 * It loops a maximum of 3n times, each pass is cheap,
 * and it can work with multiple levels of children,
 * parents and grandparents.
 */
function makeHierarchical($flatListOfObjects) {
  // Create new reference list keyed on "id",
  // assuming "id" is a positive integer.
  $idList = array();
  foreach ($flatListOfObjects as $o) {
    $idList[$o->id] = $o;
  }

  // Connect children with their parents, but don't remove
  // them from top level yet, because they themselves might
  // also be parents with children to be attached.
  foreach ($idList as $o) {
    if ($o->parent > 0) {
      // Add as a child item to the children list of the parent.
      $idList[$o->parent]->children[] = $o;
    }
  }

  // Remove children from top level of the list.
  foreach ($idList as $key => $o) {
    if ($o->parent > 0) {
      unset($idList[$key]);
    }
  }

  // Return our newly created hierarchical list.
  return $idList;
}

/**
 * Test Functions
 */
function test_makeHierarchical() {
  function makeObj($id, $name, $parent=0) {
    $o = new stdClass();
    $o->id = $id;
    $o->name = $name;
    $o->parent = $parent;
    return $o;
  }

  $flatList[] = makeObj(1, 'Parent1');
  $flatList[] = makeObj(7, 'Child1', 1);
  $flatList[] = makeObj(9, 'Child2', 1);
  $flatList[] = makeObj(2, 'Parent2');
  $flatList[] = makeObj(88, 'Childof2', 2);

  print_r($flatList);
  $newList = makeHierarchical($flatList);
  print_r($newList);
}

test_makeHierarchical();

?>