Pergunta

Eu tenho uma matriz neste formato:

Array
(
    [0] => Array
        (
            [28th February, 2009] => 'bla'
        )

    [1] => Array
        (
            [19th March, 2009] => 'bla'
        )

    [2] => Array
        (
            [5th April, 2009] => 'bla'
        )

    [3] => Array
        (
            [19th April, 2009] => 'bla'
        )

    [4] => Array
        (
            [2nd May, 2009] => 'bla'
        )

) 

Eu quero classificá-los na ordem crescente das datas (com base no mês, dia e ano). Qual é a melhor maneira de fazer isso?

Originalmente, os e-mails estão a ser obtidas no formato de data MySQL, pelo que a sua possível para mim para obter a matriz neste estado:

Array
[
    ['2008-02-28']='some text',
    ['2008-03-06']='some text'
]

Talvez quando seu neste formato, posso loop através deles, remover todas as marcas (hífen) o '-' que eles são deixados como integars, classificá-los usando array_sort() e loop através deles mais uma vez para classificá-los? Prefere se houvesse outra maneira que eu estaria fazendo 3 laços com este por usuário.

Graças.

Edit: Eu também poderia fazer isso:

$array[$index]=array('human'=>'28 Feb, 2009',
                   'db'=>'20080228',
                   'description'=>'Some text here');

Mas usando este, haveria alguma maneira de classificar a matriz com base apenas no elemento 'db'?

Edit 2: Atualizado var_dump inicial

Foi útil?

Solução

Use o formato ISO (yyyy-mm-dd) em vez do formato "Inglês", e depois é só usar o ksort função para obtê-los na ordem correta.

Não há necessidade de remover os hífens, ksort vai fazer uma comparação alfanumérica nas teclas de cordas, eo formato yyyy-mm-dd funciona perfeitamente bem como a ordem lexical é o mesmo que a ordem de data real.

Editar Eu vejo que você já corrigiu sua pergunta para mostrar que você realmente tem uma matriz de matrizes, e que a chave de ordenação é nas sub-matrizes. Neste caso, você deve usar uksort como recomendado em outros lugares, mas eu recomendo que você vá com seu próprio editar e classificar com base no DB data formatada, em vez de analisar o formato legível:

function cmp($a, $b)
{
    global $array;
    return strcmp($array[$a]['db'], $array[$b]['db']);
}

uksort($array, 'cmp');

Outras dicas

Na verdade, use isto:

usort($array, "cmp");

function cmp($a, $b){ 
    return strcmp($b['db'], $a['db']); 
}

:)

function cmp($a, $b) {    
    global $array;    
    return strcmp($array[$a]['db'], $array[$b]['db']); 
}    
uksort($array, 'cmp');

Eu acho que é melhor para a função uso usort() vez de uksort(), porque às vezes você não pode usar variáveis ??globais em tudo e mesmo assim o uso de variáveis ??globais não é uma boa prática também.

Você também pode usar função anônima.

// Sort in chronological order.
usort($array, function($a, $b) {
  return strcmp($a['db'], $b['db']);
});
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top