views:

68

answers:

2

I have an array with values like:

Array
(
    [0] => Array
        (
            [parent] => Basic
            [parentId] => 1
            [child] => Birthday
            [childId] => 2
        )

    [1] => Array
        (
            [parent] => Basic
            [parentId] => 1
            [child] => Gender
            [childId] => 3
        )

    [2] => Array
        (
            [parent] => Geo
            [parentId] => 10
            [child] => Current City
            [childId] => 11
        )

    [3] => Array
        (
            [parent] => Known me
            [parentId] => 5
            [child] => My personality
            [childId] => 7
        )

    [4] => Array
        (
            [parent] => Known me
            [parentId] => 5
            [child] => Best life moment
            [childId] => 8
        )
)

And I want to filter this array such that their filtration based on parent index, and the final result would be like:

Array
(
    [0] => Array
        (
            [parent] => Basic
            [parentId] => 1
            [child] => Array
                (
                    [0] => Birthday
                    [1] => Gender
                )

        )

    [1] => Array
        (
            [parent] => Geo
            [parentId] => 10
            [child] => Array
                (
                    [0] => Current City                  
                )

        )

    [2] => Array
        (
            [parent] => Known me
            [parentId] => 5
            [child] => Array
                (
                    [0] => My personality
                    [1] => Best life moment
                )

        )
)

For that I coded :

$filter = array();
$f = 0;
for ($i=0; $i<count($menuArray); $i++) {
    $c = 0;
    for( $b = 0; $b < count($filter); $b++ ){

        if( $filter[$b]['parent'] == $menuArray[$i]['parent'] ){
            $c++;
        }
    }
    if ($c == 0) {
        $filter[$f]['parent'] = $menuArray[$i]['parent'];
        $filter[$f]['parentId'] = $menuArray[$i]['parentId'];
        $filter[$f]['child'][] = $menuArray[$i]['child'];
        $f++;
    } 
}

But it results :

Array
(
    [0] => Array
        (
            [parent] => Basic
            [parentId] => 1
            [child] => Array
                (
                    [0] => Birthday
                )

        )

    [1] => Array
        (
            [parent] => Geo
            [parentId] => 10
            [child] => Array
                (
                    [0] => Current City
                )

        )

    [2] => Array
        (
            [parent] => Known me
            [parentId] => 5
            [child] => Array
                (
                    [0] => My personality
                )

        )
)

Could anyone point out my missing LOC?

A: 

The next piece of code is completely untested, and based on the idea that it's sorted by parentId.

$filter = array();
$option = null;
for( $i = 0; $i < count( $menuArray ); $i++ ) {
    if( count( $filter ) < 1 || $filter[count($filter)-1]['parentId'] != $menuArray['parentId'] ) {
        if( $option != null ) {
            $filter[]   = $option;
        }

        $option = array(
            "parent"    => $menuArray[$i]['parent'],
            "parentId"  => $menuArray[$i]['parentId'],
            "child"     => array()
        );
    }

    $option['child'][]  = $menuArray[$i]['child'];
}

$filter[]   = $option; // one last time, because we left the loop already.
unset( $option ); // we don't need it anymore.

What it does, it creates a $option for every parent. As soon as we hit the next parentId we add the current $option to the $filter array and create a new $option object.

All the children just keep getting added to the current $option.

CharlesLeaf
+1  A: 

Try:

$filter = array();
foreach ($menuArray as $menu) {
  if (!array_key_exists($menu['parent_id'], $filter)) {
    $filter[$menu['parent_id']] = array(
      'parent' => $menu['parent'],
      'parent_id' => $menu['parent_id'],
      'child' => array()
    );
  }
  $filter[$menu['parent_id']]['child'][$menu['child_id']] = $menu['child'];
}

This will produce an array like:

Array
(
    [1] => Array
        (
            [parent] => Basic
            [parentId] => 1
            [child] => Array
                (
                    [2] => Birthday
                    [3] => Gender
                )

        )

    [10] => Array
        (
            [parent] => Geo
            [parentId] => 10
            [child] => Array
                (
                    [11] => Current City                  
                )

        )

    [5] => Array
        (
            [parent] => Known me
            [parentId] => 5
            [child] => Array
                (
                    [7] => My personality
                    [8] => Best life moment
                )

        )
)

Notice that the array indexes match the IDs. You can't loop this with a for loop but you can foreach ($filter as $parent_id=>$parent) correctly. If you want to you can change line 4 of my code to $filter['key_' . $menu['parent_id']] to force a string and a for loop will work

Matt S