2010-07-31 5 views
0

Y at-il loin je peux trier le tableau suivant dans le bon ordre?Tableau de tri des dates stockées dans une chaîne

Array 
(
    [0] => apr 
    [1] => aug 
    [2] => dec 
    [3] => feb 
    [4] => jan 
    [5] => jul 
    [6] => jun 
    [7] => mar 
    [8] => may 
    [9] => nov 
    [10] => oct 
    [11] => sep 
) 

REMARQUE Le tableau me vient comme ça, et parfois il n'aura pas tous les mois.

Évidemment, je veux dans l'ordre chronologique.

Merci

+0

Êtes-vous toujours avoir quelques mois, et dans ce format? – NullUserException

+0

Oui, les mois sont toujours ce format, juste un ordre différent à chaque fois – Lizard

Répondre

4
function sort_months($item_1, $item_2) 
{ 
    $item_1 = strtotime('1 ' . $item_1 . ' 2000'); 
    $item_2 = strtotime('1 ' . $item_2 . ' 2000'); 
    if($item_1 == $item_2) 
    { 
     return 0; 
    } 
    return $item_1 > $item_2 ? 1 : -1; 
} 

$arr = array 
(
    'apr', 
    'aug', 
    'dec', 
    'feb', 
    'jan', 
    'jul', 
    'jun', 
    'mar', 
    'may', 
    'nov', 
    'oct', 
    'sep' 
); 

usort($arr, 'sort_months'); 
1

Utilisez usort avec un comparateur personnalisé que vous définissez. Le comparateur personnalisé fonctionnera avec le format de date traité par votre code et renverra un entier supérieur, inférieur ou égal à zéro en fonction de la comparaison des deux dates passées.

1

Pour mantenir association d'index et d'autres valeurs de chaîne, essayez le code ci-dessous:

function find_position($needle, $haystack) { 

    // put here the elements in order 
    //$defined_order = array('jan', 'fev', 'mar', 'abr', 'mai', 'jun', 'jul', 'ago', 'set', 'out', 'nov', 'dez'); 
    $defined_order = array('jan', 'feb', 'mar', 'apr', 'may', 'jun', 'jul', 'aug', 'sep', 'oct', 'nov', 'dec'); 

    $needle_order = -1; 
    foreach($defined_order as $pos => $item) { 
     if($needle == $item) { 
      $needle_order = $pos; 
      break; 
     } 
    } 

    return($needle_order); 
} 

function order_array($unsorted_arr) { 

    $key_orders = array(); 
    $not_available = array(); 
    foreach($unsorted_arr as $key => $val) { 
     if($position = find_position($val, $unsorted_arr)) { 
      $key_orders[$key] = $position; 
     } else { 
      $not_available[$key] = $val; 
     } 
    } 

    asort($key_orders); 

    $ordered = array(); 
    foreach($key_orders as $key => $posit) { 
     $ordered[$key] = $unsorted_arr[$key]; 
    } 

    return($ordered); 
    // OR 
    // return(array('ordered'=>$ordered, 'not_available'=>$not_available)); 
} 


$unsorted = array(0 => 'apr', 1 => 'aug', 2 => 'dec', 3 => 'feb', 4 => 'jan', 5 => 'jul', 6 => 'jun', 7 => 'mar', 8 => 'may', 9 => 'nov', 10 => 'oct', 11 => 'sep'); 

$sorted = order_array($unsorted);