2011-11-02 27 views
5

bien, tengo una matriz que se utiliza para el transporte de nombres, que se ve así:ordenar una matriz asociativa multidimensional?

array(2) { 
    [0]=> 
    array(3) { 
    ["firstName"]=> 
    string(3) "Joe" 
    ["lastName"]=> 
    string(5) "Black" 
    ["uid"]=> 
    int(3225) 
    } 
    [1]=> 
    array(3) { 
    ["firstName"]=> 
    string(4) "John" 
    ["lastName"]=> 
    string(3) "Doe" 
    ["uid"]=> 
    int(3516) 
    } 
} 

Ahora, ¿cómo puedo ordenar esta matriz por lastName?

+9

Mientras que las preguntas relacionadas podrían no ser una relación 1: 1 partido para sus circunstancias, la mayoría de ellos contienen la función y la explicación necesaria para completar su tarea. –

+2

posible duplicado de [Ordenar una matriz multidimensional] (http://stackoverflow.com/questions/648405/sort-a-multi-dimensional-array) – Neal

+2

Respondió casi exactamente (las necesidades clave se modificaron) en http: // stackoverflow .com/questions/3596011/sort-an-array-base-on-key – jprofitt

Respuesta

15

Stackoverflow tiene un montón de preguntas similares, pero te voy a dar un ejemplo rápido. Para esto, puede usar la función usort().

PHP 5.3 ejemplo (no el que más, pero podría ser más fácil de entender):

uasort($array, function ($i, $j) { 
    $a = $i['lastName']; 
    $b = $j['lastName']; 
    if ($a == $b) return 0; 
    elseif ($a > $b) return 1; 
    else return -1; 
}); 
+0

¿Es necesario todo el 'if .. else'? Creo que esto podría refactorizarse para simplemente 'devolver $ i ['lastName']> $ j ['lastName'];' – galdikas

+0

@galdikas El documento dice que la función debería devolver 1, 0 o -1. No he tocado PHP durante mucho tiempo sin embargo. – kapa

2

Como lo publiqué en php.net, puede utilizar esta función:

<?php 

function sksort(&$array, $subkey="id", $sort_ascending=false) { 

    if (count($array)) 
     $temp_array[key($array)] = array_shift($array); 

    foreach($array as $key => $val){ 
     $offset = 0; 
     $found = false; 
     foreach($temp_array as $tmp_key => $tmp_val) 
     { 
      if(!$found and strtolower($val[$subkey]) > strtolower($tmp_val[$subkey])) 
      { 
       $temp_array = array_merge( (array)array_slice($temp_array,0,$offset), 
              array($key => $val), 
              array_slice($temp_array,$offset) 
             ); 
       $found = true; 
      } 
      $offset++; 
     } 
     if(!$found) $temp_array = array_merge($temp_array, array($key => $val)); 
    } 

    if ($sort_ascending) $array = array_reverse($temp_array); 

    else $array = $temp_array; 
} 

?> 
1

corto y reutilizable método:

usort($array, 'nameSort'); 

function nameSort($a, $b) 
{ 
    return strcmp($a['lastName'], $b['lastName']); 
} 
+1

También tenga en cuenta que si está haciendo esto en una clase, pasaría una matriz en lugar de una cadena para la ordenación, así: 'usort ($ array, array ($ this, 'nameSort'));' – Justin

Cuestiones relacionadas