Agrupar matriz por valores de subarray

Aqui está um desafio interessante. Eu tenho uma série de subarquetas no seguinte formato:

array ( a => array ( id = 20, name = chimpanzee ) b => array ( id = 40, name = meeting ) c => array ( id = 20, name = dynasty ) d => array ( id = 50, name = chocolate ) e => array ( id = 10, name = bananas ) f => array ( id = 50, name = fantasy ) g => array ( id = 50, name = football ) ) 

E eu gostaria de agrupá-lo em uma nova matriz com base no campo id em cada subarray.

 array ( 10 => array ( e => array ( id = 10, name = bananas ) ) 20 => array ( a => array ( id = 20, name = chimpanzee ) c => array ( id = 20, name = dynasty ) ) 40 => array ( b => array ( id = 40, name = meeting ) ) 50 => array ( d => array ( id = 50, name = chocolate ) f => array ( id = 50, name = fantasy ) g => array ( id = 50, name = football ) ) ) 

Obrigado!

 $arr = array(); foreach($old_arr as $key => $item) { $arr[$item['id']][$key] = $item; } ksort($arr, SORT_NUMERIC); 
 foreach($array as $key => $value){ $newarray[$value['id']][$key] = $value; } var_dump($newarray); 

Moleza; fácil; baba 😉

O código a seguir adapta o código do @Tim Cooper para mitigar o Undefined index: id erros de Undefined index: id caso um dos arrays internos não contenha um id .

 $arr = array(); foreach($old_arr as $key => $item) { if(array_key_exists('id', $item)) $arr[$item['id']][$key] = $item; } ksort($arr, SORT_NUMERIC); 

No entanto, ele descartará arrays internos sem um id.

Por exemplo

 $old_arr = array( 'a' => array ( 'id' => 20, 'name' => 'chimpanzee' ), 'b' => array ( 'id' => 40, 'name' => 'meeting' ), 'c' => array ( 'id' => 20, 'name' => 'dynasty' ), 'd' => array ( 'id' => 50, 'name' => 'chocolate' ), 'e' => array ( 'id' => 10, 'name' => 'bananas' ), 'f' => array ( 'id' => 50, 'name' => 'fantasy' ), 'g' => array ( 'id' => 50, 'name' => 'football' ), 'h' => array ( 'name' => 'bob' ) ); 

irá soltar o conjunto ‘h’ completamente.

Você também pode usar Arrays :: gorupBy forme ouzo-goodies :

 $groupBy = Arrays::groupBy($array, Functions::extract()->id); print_r($groupBy); 

E resultado:

 Array ( [20] => Array ( [0] => Array ( [id] => 20 [name] => chimpanzee ) [1] => Array ( [id] => 20 [name] => dynasty ) ) [40] => Array ( [0] => Array ( [id] => 40 [name] => meeting ) ) [50] => Array ( [0] => Array ( [id] => 50 [name] => chocolate ) [1] => Array ( [id] => 50 [name] => fantasy ) [2] => Array ( [id] => 50 [name] => football ) ) [10] => Array ( [0] => Array ( [id] => 10 [name] => bananas ) ) ) 

E aqui estão documentos para Arrays e Funções .

  array ( 'id' => 20, 'names' => 'chimpanzee' ), 'b' => array ( 'id' => 40, 'name' => 'meeting' ), 'c' => array ( 'id' => 20, 'name' => 'dynasty' ), 'd' => array ( 'id' => 50, 'name' => 'chocolate' ), 'e' => array ( 'id' => 10, 'name' => 'bananas' ), 'f' => array ( 'id' => 50, 'name' => 'fantasy' ), 'g' => array ( 'id' => 50, 'name' => 'football' ) ); $result = array(); foreach($array as $key => $value){ $id = $value['id']; if(!isset($result[$id])) $result[$id] = array(); $result[$id] = array($key => $value); } var_dump($result); ?> 

demo: http://codepad.org/yvU95m9k