2011-11-02 25 views
5

Va bene, ho una matrice che viene utilizzato per il trasporto di nomi, sembra che questo:ordina un array associativo multidimensionale?

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) 
    } 
} 

Ora, come faccio a ordinare questo array da lastName?

+9

Mentre le questioni connesse potrebbero non essere un 1: 1 corrispondere alle circostanze, la maggior parte di esse contiene la funzione e le spiegazioni necessarie per completare l'attività. –

+2

possibile duplicato di [Ordina un array multidimensionale] (http://stackoverflow.com/questions/648405/sort-a-multi-dimensional-ray) – Neal

+2

Risposta quasi esatta (le esigenze principali sono cambiate) all'indirizzo http: // stackoverflow .com/questions/3596011/sort-an-array-base-on-key – jprofitt

risposta

15

StackOverflow ha un sacco di domande simili, ma mi permetta di darle un esempio veloce. Per questo, è possibile utilizzare la funzione usort().

PHP 5.3 esempio (non il più bello, ma potrebbe essere più facile da capire):

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

È necessario il comando "if .. else"? Penso che questo possa essere rifattorizzato semplicemente 'return $ i ['lastName']> $ j ['lastName'];' – galdikas

+0

@galdikas Il documento dice che la funzione dovrebbe restituire 1, 0 o -1. Non ho toccato PHP per molto tempo però. – kapa

2

Come ho scritto nel php.net, è possibile utilizzare questa funzione:

<?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 e riutilizzabile metodo:

usort($array, 'nameSort'); 

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

Inoltre, se si sta facendo questo in una classe, si passa una matrice invece di una stringa a usort, in questo modo: 'usort ($ array, array ($ this, 'nameSort'));' – Justin