Question

J'ai un tableau:

Array (
    [0] => stdClass Object (
        [user_id] => 1
        [ID] => 1
        [user_login] => admin
        [display_name] => admin
        [user_email] => webbinformation@nacka.se
        [meta_value] => a:1:{s:13:\"administrator\";s:1:\"1\";}
    )
    [1] => stdClass Object (
        [user_id] => 4
        [ID] => 4
        [user_login] => ungtinflytande
        [display_name] => ungtinflytande
        [user_email] => klarakviberg@gmail.com
        [meta_value] => a:1:{s:13:\"administrator\";s:1:\"1\";}
    )
    [2] => stdClass Object (
        [user_id] => 5
        [ID] => 5
        [user_login] => inflytandepilot
        [display_name] => inflytandepilot
        [user_email] => hildalundgren@hotmail.com
        [meta_value] => a:1:{s:6:\"author\";s:1:\"1\";}
    )
    [3] => stdClass Object (
        [user_id] => 11
        [ID] => 11
        [user_login] => matsbohman
        [display_name] => matsbohman
        [user_email] => mats.bohman@nacka.se
        [meta_value] => a:1:{s:6:\"editor\";s:1:\"1\";}
    )
    [4] => stdClass Object (
        [user_id] => 12
        [ID] => 12
        [user_login] => klarakviberg
        [display_name] => klarakviberg
        [user_email] => nastasteg@nacka.se
        [meta_value] => a:1:{s:13:\"administrator\";s:1:\"1\";}
    )
)

... que je veux trier par la clé display_name. J'imprime actuellement comme ceci:

foreach ($blogusers as $bloguser) {
    ...
}

Comment puis-je faire?

Était-ce utile?

La solution

QU'AVEC usort () - http://php.net/usort

Ma suggestion serait:

    function cmp($a, $b)
    {
        return strcmp($a->display_name, $b->display_name);
    }

    usort($blogusers, "cmp");

    foreach ($blogusers as $bloguser)
    {
        ...

Autres conseils

Voir usort: http://php.net/manual/en/function.usort .php

usort($array, "my_cmp");

function my_cmp($a, $b) {
  if ($a->display_name == $b->display_name) {
    return 0;
  }
  return ($a->display_name < $b->display_name) ? -1 : 1;
}

Je trouve réponse à https: // joshtronic. com / 2013/09/23 / tri-spécifique-tableau-associatif clé /

function sortBy($field, &$array, $direction = 'asc')
{
    usort($array, create_function('$a, $b', '
        $a = $a["' . $field . '"];
        $b = $b["' . $field . '"];

        if ($a == $b)
        {
            return 0;
        }

        return ($a ' . ($direction == 'desc' ? '>' : '<') .' $b) ? -1 : 1;
    '));

    return true;
}

Et maintenant appeler cette fonction par clé du tableau spécifique.

$newArray = sortBy('display_name',   $blogusers);

Et si tri dans asc / desc il suffit d'ajouter un argument,

sortBy('display_name',   $blogusers, 'desc');

Votre tableau ressemble le résultat d'une requête de base de données. Si cela est le cas, laissez la base de données effectuer le tri. Ajoutez juste ORDER BY display_name à la requête

Jetez un oeil à l'article suivant. Il ne décrit comment utiliser usort() et décrit également comment utiliser create_function() afin que vous puissiez utiliser la fonction unique tri sur différents champs (avec direction asc requis ou desc).

http://phpave.com/sorting-associative-array-specific- clé /

Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow
scroll top