简体   繁体   English

在PHP中按字段分组多维数组

[英]Grouping multidimensional arrays in PHP by field

UPDATE var_export version of the array HERE 此处 更新数组的var_export版本

I have the following array which I would like to group the elements/children by their UNILEVEL value: 我有以下数组,我想按元素/子项的UNILEVEL值对它们进行分组:

array( 
    0 => array(
         "member_id" => 3,
         "unilevel" => 1, 
         "children" => array( 
             0 => array( 
                 "member_id" => 4,
                 "unilevel" => 2,
                 "children" => array( 
                     0 => array( 
                         "member_id" => 6,
                         "unilevel" => 3,
                         "children" => array( 
                             0 => array(
                                 "member_id" => 7,
                                 "unilevel" => 4 ) ) ) ) ) 
             1 => array( 
                 "member_id" => 9
                 "unilevel" => 2 ) ) )
    1 => array( 
        "member_id" => 5,
        "unilevel" => 1,
        "children" => array( 
            0 => array( 
                "member_id" => 8,
                "unilevel" => 2,
                "children" => array( 
                    0 => array( 
                        "member_id" => 10,
                        "unilevel" => 3 ) ) ) ) ) ) 

The Controller below has a function named, groupPerlevel which does the grouping, but it only groups the first parent right now, it's already a recursive function, I am not sure why it's not putting the second parent's elements on the unilevel groupings. 下面的Controller有一个名为groupPerlevel的函数,它可以进行分组,但它现在仅对第一个父级进行分组,它已经是一个递归函数,我不确定为什么不将第二个父级的元素放在单层分组中。

class TestController extends Controller {
    private $group = array();

    private function setGroup($value) {
        $this->group = $this->group + $value;
    }

    private function getGroup() {
        return $this->group;
    }

    public function create()
    {
        $this->groupPerlevel($tree);
        dd($this->getGroup());
    }

    private function groupPerlevel(array $items)
    {
        var_dump($items);
        $grouparr = $this->getGroup();

        $newkey = 0;
        $templevel = 1;

        foreach($items as $key => $val) {
            if($templevel == $val->unilevel) {
                $grouparr[$templevel][$newkey] = $val;
                $this->setGroup($grouparr);
            } else {
                if(isset($grouparr[$val->unilevel][$newkey])) {
                    $count = count($grouparr[$val->unilevel]);
                    $grouparr[$val->unilevel][$count] = $val;
                    $this->setGroup($grouparr);
                } else  {
                    $grouparr[$val->unilevel][$newkey] = $val;
                }
            }

            if(isset($val->children)) {
                $children = $val->children;
                unset($val->children);
                $this->groupPerlevel($children);   
            } 
            $newkey++;
        }
        $this->setGroup($grouparr);
    }
}

The following array would be my desired output. 以下数组将是我想要的输出。 array(4) { [1] is the UNILEVEL (group) so all elements/children should be in their proper unilevel group based on their unilevel field value. array(4){ [1]是UNILEVEL(组),因此所有元素/子级均应基于其单级字段值而位于其适当的单级组中。 But it only does that for the first parent, the second parent doesn't group. 但这仅适用于第一个父级,第二个父级不分组。

array(
1 => array( 
    0 => array( 
        "member_id" => 3,
        "unilevel" => 1 ) )
4 => array( 
    0 => array( 
        "member_id" => 7,
        "unilevel" => 4 ) )
3 => array( 
    0 => array ( 
        "member_id" => 6,
        "unilevel" => 3 ) )
2 => array( 
    0 => array( 
        "member_id" => 4,
        "unilevel" => 2 
    1 => array( 
        "member_id" => 9
        "unilevel" => 2 )))

Sorry for late response try this 对不起,迟到了请试试看

$arr=array("shiva" => array("member_id" => "3","unilevel" => "1","children" => array("0" => array("member_id" => "4","unilevel" => "2","children" => array("0" => array("member_id" => "6", "unilevel" => "3", "children" => array( "0" => array( "member_id" => "7", "unilevel" => "4" ) ) ) ) ), "1" => array( "member_id" => "9", "unilevel" => "2" ))),"1" => array("member_id" => "5","unilevel" => "1","children" => array("0" => array("member_id" => "8","unilevel" => "2", "children" => array( "0" => array( "member_id" => "10", "unilevel" => "3" ) ) ) ) ) );


 function check($arr){

      if(is_array($arr)){

       foreach($arr as $arr1){

         foreach($arr1 as $arr2){

           if(is_array($arr2)){

             return true;               

           }

         }

       }   

     }
     else{

      return false;       

     }

      return false; 

  } 

$i=0;
while(check($arr)){

  foreach($arr as $arr1key=>$arr1val){

    foreach($arr1val as $arr2key=>$arr2val){

         if(is_array($arr2val)){

        $arr[]=$arr[$arr1key][$arr2key];

        unset($arr[$arr1key][$arr2key]);


      }        

   }      


  }  

}






foreach($arr as $arr1key=>$arr1val)
{

  if(count($arr1val)==0){
    unset($arr[$arr1key]);
  }    
}

//print_r($arr);

$result=array();
$values=array();


foreach($arr as $arr1key=>$arr1val)
{

  if(((array_key_exists("unilevel", $arr1val)) || (array_key_exists("member_id", $arr1val)))==true)
  {


      $key=$arr1val['unilevel'];
      $result[0][$key][]=array("unilevel"=>$arr1val["unilevel"],"member_id"=>$arr1val["member_id"]);


  }


}

print_r($result);

Result: 结果:

Array ( [0] => Array ( [1] => Array ( [0] => Array ( [unilevel] => 1 [member_id] => 3 ) [1] => Array ( [unilevel] => 1 [member_id] => 5 ) ) [2] => Array ( [0] => Array ( [unilevel] => 2 [member_id] => 4 ) [1] => Array ( [unilevel] => 2 [member_id] => 9 ) [2] => Array ( [unilevel] => 2 [member_id] => 8 ) ) [3] => Array ( [0] => Array ( [unilevel] => 3 [member_id] => 6 ) [1] => Array ( [unilevel] => 3 [member_id] => 10 ) ) [4] => Array ( [0] => Array ( [unilevel] => 4 [member_id] => 7 ) ) ) ) Array([0] => Array([1] => Array([0] => Array([unilevel] => 1 [member_id] => 3)[1] => Array([unilevel] => 1 [ member_id] => 5))[2] =>数组([0] =>数组([unilevel] => 2 [member_id] => 4)[1] => Array([unilevel] => 2 [member_id] => 9)[2] =>数组([unilevel] => 2 [member_id] => 8))[3] => Array([0] => Array([unilevel] => 3 [member_id] => 6)[1] =>数组([unilevel] => 3 [member_id] => 10))[4] => Array([0] => Array([unilevel] => 4 [member_id] => 7) )))

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM