3v4l.org

run code in 300+ PHP versions simultaneously
<?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