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

)

)

)

)

基于bert实现关系三元组抽取python源码+数据集+项目说明.zip基于bert实现关系三元组抽取python源码+数据集+项目说明.zip基于bert实现关系三元组抽取python源码+数据集+项目说明.zip基于bert实现关系三元组抽取python源码+数据集+项目说明.zip基于bert实现关系三元组抽取python源码+数据集+项目说明.zip 个人大四的毕业设计、课程设计、作业、经导师指导并认可通过的高分设计项目,评审平均分达96.5分。主要针对计算机相关专业的正在做毕设的学生和需要项目实战练习的学习者,也可作为课程设计、期末大作业。 [资源说明] 不懂运行,下载完可以私聊问,可远程教学 该资源内项目源码是个人的毕设或者课设、作业,代码都测试ok,都是运行成功后才上传资源,答辩评审平均分达到96.5分,放心下载使用! 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),供学习参考。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值