<?php
$Arr1=Array
(
0 => Array
(
"id" => "4123",
"test_number" => "1",
"sat_total" => "1050"
),
1 => Array
(
"id" => "4123",
"test_number" => "2",
"sat_total" => "1130"
),
2 => Array
(
"id" => "4123",
"test_number" => "3",
"sat_total" => "1120"
),
3 => Array
(
"id" => "5555",
"test_number" => "1",
"sat_total" => "1130"
),
4 => Array
(
"id" => "5555",
"test_number" => "2",
"sat_total" => "1160"
)
);
$ids = array_column($Arr1, "id");
$sat = array_column($Arr1, "sat_total");
Foreach(array_unique($ids) as $id){
$new[$id] = ["id" => $id];
$tmp = array_values(array_intersect_key($sat,array_intersect_key($Arr1, array_intersect($ids, [$id]))));
For($i=1;$i<=count($tmp);$i++) $new[$id]["Score" . $i] = $tmp[$i-1];
}
Var_dump($new);
- Output for 7.1.0 - 7.1.33, 7.2.0 - 7.2.33, 7.3.0 - 7.3.33, 7.4.0 - 7.4.33, 8.0.0 - 8.0.30, 8.1.0 - 8.1.33, 8.2.0 - 8.2.29, 8.3.0 - 8.3.25, 8.4.1 - 8.4.12
- array(2) {
[4123]=>
array(4) {
["id"]=>
string(4) "4123"
["Score1"]=>
string(4) "1050"
["Score2"]=>
string(4) "1130"
["Score3"]=>
string(4) "1120"
}
[5555]=>
array(3) {
["id"]=>
string(4) "5555"
["Score1"]=>
string(4) "1130"
["Score2"]=>
string(4) "1160"
}
}
preferences:
150.51 ms | 408 KiB | 5 Q