for循环 php 增加数组维数_PHP数组在循环中创建多维数组

我有一个关联的多维数组,如下所示

$data = array();

$data = Array (

[0] => Array ( [class] => 1styear [branch] => IT [Exam] => SEM1 [student name] => Alex [Bio] => Good Boy )

[1] => Array ( [class] => 2ndyear [branch] => Finance [Exam] => SEM1 [student name] => Mark [Bio] => Intelligent )

[2] => Array ( [class] => 2ndyear [branch] => IT [Exam] => SEM1 [student name] => Shaun [Bio] => Football Player )

[3] => Array ( [class] => 1styear [branch] => Finance [Exam] => SEM2 [student name] => Mike [Bio] => Sport Player )

[4] => Array ( [class] => 1styear [branch] => IT [Exam] => SEM2 [student name] => Martin [Bio] => Smart )

[5] => Array ( [class] => 1styear [branch] => IT [Exam] => SEM1 [student name] => Philip [Bio] => Programmer )

)

我需要根据上面数组中的类似元素创建新数组.意味着我必须创建阵列组.例如,类元素具有重复的第1年和第2年的值.所以它会产生一系列独特的元素.然后再次类是父数组和内部类数组应该有基于分支的数组和内部的检查数组和里面的数组应该有学生名和生物的关联数组.

所以基本上数组应该是这样的

array(

"1styear" => array(

"IT" => array(

"SEM1" => array(

array(

"student name" => "Alex",

"Bio" => "Good Boy"

),

array(

"student name" => "Philip",

"Bio" => "Programmer"

)

),

"SEM2" => array(

array(

"student name" => "Martin",

"Bio" => "Smart"

)

)

)

),

"2ndyear" => array(

"Finance" => array(

"SEM1" => array(

array(

"student name" => "Mark",

"Bio" => "Intelligent"

)

),

"SEM2" => array(

array(

"student name" => "Mike",

"Bio" => "Sport Player"

)

)

)

)

);

为了使基于类的组我喜欢下面哪个工作正常,但如何在其中创建数组

$classgroup = array();

foreach($data as $inarray){

$classgroup[$inarray['class']][] = $inarray;

}

$classarray = array();

foreach($classgroup as $key => $value){

echo $key; // output is 1styear and secondyear

create array like above

}

– – – – – – – – – – – – – – – – -编辑 – – – – – – – – ——————

从下面的循环

foreach($data as $array){

$grouped[$array["class"]][$array["branch"]][$array["Exam"]][]=array("student name"=>$array["student name"],"Bio"=>$array["Bio"]);

}

我得到了预期的o / p

但如果我需要另一个这样的o / p

预计o / p

array(

'1styear' =>

array (

0 =>

array(

'Exam' => 'SEM1',

'branch' =>

array (

0 => 'IT'

),

),

1 =>

array(

'Exam' => 'SEM2',

'branch' =>

array (

0 => 'IT'

),

),

),

'2ndyear' =>

array (

0 =>

array(

'Exam' => 'SEM1',

'branch' =>

array (

0 => 'Finance',

),

),

1 =>

array(

'Exam' => 'SEM2',

'branch' =>

array (

0 => 'Finance'

),

)

),

)

我尝试了循环但没有按预期获得o / p

foreach($data as $array){

$grouped[$array["class"]][]=array("Exam"=>$array["Exam"],"branch"=>$array["branch"]);

}

最佳答案 循环中的单行!

foreach($data as $array){

$grouped[$array["class"]][$array["branch"]][$array["Exam"]][]=array("student name"=>$array["student name"],"Bio"=>$array["Bio"]);

}

$groups产生:

Array(

[1styear] => Array(

[IT] => Array(

[SEM1] => array(

[0] => array(

[student name] => Alex,

[Bio] => Good Boy

),

[1] => array(

[student name] => Philip,

[Bio] => Programmer

)

),

[SEM2] => array(

[0] => array(

[student name] => Martin,

[Bio] => Smart

)

)

),

[Finance] => array(

[SEM2] => array(

[0] => array(

[student name] => Mike,

[Bio] => Sport Player

)

)

)

),

[2ndyear] => array(

[Finance] => array(

[SEM1] => array(

[0] => array(

[student name] => Mark,

[Bio] => Intelligent

)

)

),

[IT] => array(

[SEM1] => array(

[0] => array(

[student name] => Shaun,

[Bio] => Football Player

)

)

)

)

)

你的后续案例,更有趣/更具挑战性.我不得不把我不经常玩的一些功能搞得粉碎.看一下这个:

$data = array (

array ( "class"=>"1styear","branch"=>"IT","Exam"=>"SEM1","student name"=>"Alex","Bio"=>"Good Boy"),

array ( "class"=>"2ndyear","branch"=>"Finance","Exam"=>"SEM1","student name"=>"Mark","Bio"=>"Intelligent" ),

array ( "class"=>"2ndyear", "branch"=>"IT","Exam"=>"SEM1","student name"=>"Shaun","Bio"=>"Football Player" ),

array ( "class"=>"1styear","branch"=>"Finance","Exam"=>"SEM2","student name"=>"Mike","Bio"=>"Sport Player" ),

array ( "class"=>"1styear","branch"=>"IT","Exam"=>"SEM2","student name"=>"Martin","Bio"=>"Smart"),

array ( "class"=>"1styear","branch"=>"IT","Exam"=>"SEM1","student name"=>"Philip","Bio"=>"Programmer" )

);

$class_keys=array_unique(array_column($data,"class")); // create array of unique class values

$Exam_keys=array_unique(array_column($data,"Exam")); // create array of unique Exam values

foreach($class_keys as $class_key){

$i=0; // "class" subarray index

foreach($Exam_keys as $Exam_key){

$q=array("class"=>$class_key,"Exam"=>$Exam_key); // this array can have 1 or more pairs

// create an array only of rows where $q's key-value pairs exist

$qualifying_array=array_filter(

$data,

function($val)use($q){

if(count(array_intersect_assoc($val,$q))==count($q)){ // total pairs found = total pairs sought

return $val;

}

},

ARRAY_FILTER_USE_BOTH

);

foreach($qualifying_array as $qa){ // push appropriate values into array

$grouped2[$class_key][$i]["Exam"]=$qa["Exam"];

$grouped2[$class_key][$i]["branch"][]=$qa["branch"];

}

if(isset($grouped2[$class_key][$i]["branch"])){ // ensure no duplicate values in "branch" subarray

$grouped2[$class_key][$i]["branch"]=array_unique($grouped2[$class_key][$i]["branch"]);

}

++$i; // increment the index for each "class" subarray

}

}

echo "

";

print_r($grouped2);

echo "

";

输出与您请求的输出不同,但我认为您只是展示它应该是什么样子.如果这不太对,请告诉我.

array(

[1styear]=>array(

[0]=>array(

[Exam]=>SEM1

[branch]=>array(

[0]=>IT

)

),

[1]=>array(

[Exam]=>SEM2

[branch]=>array(

[0]=>Finance,

[1]=>IT

)

)

),

[2ndyear]=>array(

[0]=>array(

[Exam]=>SEM1

[branch]=>array(

[0]=>Finance,

[1]=>IT

)

)

)

)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值