IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Langage PHP Discussion :

Trier un tableau multidimensionnel en fonction de la 2e dimension ?


Sujet :

Langage PHP

  1. #1
    Membre à l'essai
    Inscrit en
    Décembre 2011
    Messages
    27
    Détails du profil
    Informations forums :
    Inscription : Décembre 2011
    Messages : 27
    Points : 15
    Points
    15
    Par défaut Trier un tableau multidimensionnel en fonction de la 2e dimension ?
    Bonjour,

    Je cherche à trier des DVD en fonction d'avis.
    J'ai donc crée le tableau suivant:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    $liste[$i]['titre_dvd']
    $liste[$i]['rea_dvd']
    $liste[$i]['avis_dvd']
    (...)
    La variable $i correspond à un nombre qui définie chaque DVD.

    J'aimerais trier le tableau en fonction de la valeur de $liste[$i]['avis_dvd']

    J'ai vu qu'il existait la fonction asort() pour trier un tableau avec une colonne, mais dans mon cas comment sélectionner tous les DVD, c'est à dire tous les $liste[$i] ?


    D'avance merci!

  2. #2
    Expert éminent sénior
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Points : 16 545
    Points
    16 545
    Billets dans le blog
    12
    Par défaut
    Bonjour,

    Avec array_multisort()

  3. #3
    Membre à l'essai
    Inscrit en
    Décembre 2011
    Messages
    27
    Détails du profil
    Informations forums :
    Inscription : Décembre 2011
    Messages : 27
    Points : 15
    Points
    15
    Par défaut
    Merci pour ta réponse.

    Par contre j'ai un peu de mal à voir comment cela fonctionne dans mon cas...
    Je vois bien qu'il s'agit d'un cas similaire à celui de "Exemple #2 Trier un tableau multidimensionnel", mais là...

  4. #4
    Expert éminent sénior
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Points : 16 545
    Points
    16 545
    Billets dans le blog
    12
    Par défaut
    Ton cas relève de l'exemple n°3.
    Il faudra transformer ton tableau de valeurs.

  5. #5
    Expert éminent sénior
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Points : 16 545
    Points
    16 545
    Billets dans le blog
    12
    Par défaut
    Si tu veux, tu poster un petit jeu de données pour l'exemple.

  6. #6
    Membre à l'essai
    Inscrit en
    Décembre 2011
    Messages
    27
    Détails du profil
    Informations forums :
    Inscription : Décembre 2011
    Messages : 27
    Points : 15
    Points
    15
    Par défaut
    En fait je ne vois pas quoi faire de la première dimension $liste[$i]...

    J'ai les valeur suivantes par exemple:

    $liste[0] = array('titre_dvd' => 'titre1', 'rea_dvd' => 'reaA', 'avis_dvd' =>1);
    $liste[1] = array('titre_dvd' => 'titre2', 'rea_dvd' => 'reaB', 'avis_dvd' =>4);
    $liste[2] = array('titre_dvd' => 'titre3', 'rea_dvd' => 'reaC', 'avis_dvd' =>2);

    Je voudrais que le tableau soit donc trié comme cela:
    $liste[0]
    $liste[2]
    $liste[1]

    Enfin je sais pas si j'ai bien écrit ça...

    En réalité j'ai bien plus de colonnes que ça (annee, soustitre, support...)

  7. #7
    Expert éminent sénior
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Points : 16 545
    Points
    16 545
    Billets dans le blog
    12
    Par défaut
    Quelque chose comme ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    <?php
     
    $liste[0] = array('titre_dvd' => 'titre1', 'rea_dvd' => 'reaA', 'avis_dvd' => 1);
    $liste[1] = array('titre_dvd' => 'titre2', 'rea_dvd' => 'reaB', 'avis_dvd' => 4);
    $liste[2] = array('titre_dvd' => 'titre3', 'rea_dvd' => 'reaC', 'avis_dvd' => 2);
     
    foreach($liste as $k => $v) {
       $avis[$k] = $v['avis_dvd'];
    }
     
    array_multisort($avis, SORT_ASC, $liste);
     
    print_r($liste);
     
    ?>
    Avec ce code tu vas avoir une réindexation des clés numériques : tu vas obtenir :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    $liste[0] = array('titre_dvd' => 'titre1', 'rea_dvd' => 'reaA', 'avis_dvd' => 1);
    $liste[1] = array('titre_dvd' => 'titre3', 'rea_dvd' => 'reaC', 'avis_dvd' => 2);
    $liste[2] = array('titre_dvd' => 'titre2', 'rea_dvd' => 'reaB', 'avis_dvd' => 4);
    Le seul moyen que tu ais pour conserver ton l'id du début de $liste c'est de le passer dans ton tableau de valeurs au côté des autres clés texte.

  8. #8
    Expert éminent sénior
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Points : 16 545
    Points
    16 545
    Billets dans le blog
    12
    Par défaut
    Une remarque que je oublié de te dire : tu peux aussi très bien faire le tri directement avec le SQL non ?

  9. #9
    Membre à l'essai
    Inscrit en
    Décembre 2011
    Messages
    27
    Détails du profil
    Informations forums :
    Inscription : Décembre 2011
    Messages : 27
    Points : 15
    Points
    15
    Par défaut
    Merci pour ta réponse très complète!!!

    Je n'ai plus qu'à inclure ça dans mon projet!

    C'est vrai que ça aurait été plus simple de faire ça avec MySQL mais en fait l'avis ne se trouve pas dans ma BDD... Il est calculé en php.

  10. #10
    Membre à l'essai
    Inscrit en
    Décembre 2011
    Messages
    27
    Détails du profil
    Informations forums :
    Inscription : Décembre 2011
    Messages : 27
    Points : 15
    Points
    15
    Par défaut
    Par contre j'ai un problème:
    Quand je fais print_r($liste); ça me sort la liste non ordonnée, comme avant...

    Par contre si je fais print_r($avis); ça me sort juste les avis mais dans l'ordre:
    1
    1
    2
    4
    (...)

    Je ne comprends pas pourquoi!

  11. #11
    Membre à l'essai
    Inscrit en
    Décembre 2011
    Messages
    27
    Détails du profil
    Informations forums :
    Inscription : Décembre 2011
    Messages : 27
    Points : 15
    Points
    15
    Par défaut
    Pour moi le code suivant ne fonctionne pas...
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    array_multisort($avis, SORT_ASC, $liste);

  12. #12
    Expert éminent sénior
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Points : 16 545
    Points
    16 545
    Billets dans le blog
    12
    Par défaut
    Postes ton code stp

  13. #13
    Membre à l'essai
    Inscrit en
    Décembre 2011
    Messages
    27
    Détails du profil
    Informations forums :
    Inscription : Décembre 2011
    Messages : 27
    Points : 15
    Points
    15
    Par défaut
    Voilà mon code:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    foreach($liste as $cle => $valeur) {
       $avis[$cle] = $valeur['avis'];
    }
     
    array_multisort($avis, SORT_ASC, $liste);

  14. #14
    Membre à l'essai
    Inscrit en
    Décembre 2011
    Messages
    27
    Détails du profil
    Informations forums :
    Inscription : Décembre 2011
    Messages : 27
    Points : 15
    Points
    15
    Par défaut
    En fait ça marche très bien! Je m'excuse, j'avais du faire une erreur, je ne sais pas où...


    Merci beaucoup pour tout!

  15. #15
    Expert éminent sénior
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Points : 16 545
    Points
    16 545
    Billets dans le blog
    12
    Par défaut
    Est-ce qu'en exécutant ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    <?php
     
    $liste[0] = array('id' => 0, 'titre_dvd' => 'titre1', 'rea_dvd' => 'reaA', 'avis_dvd' => 1);
    $liste[1] = array('id' => 1, 'titre_dvd' => 'titre2', 'rea_dvd' => 'reaB', 'avis_dvd' => 4);
    $liste[2] = array('id' => 2, 'titre_dvd' => 'titre3', 'rea_dvd' => 'reaC', 'avis_dvd' => 2);
     
    foreach($liste as $k => $v) {
       $avis[$k] = $v['avis_dvd'];
    }
     
    array_multisort($avis, SORT_ASC, $liste);
     
    print_r($liste);
     
    ?>
    tu obtiens cela :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    Array (
       [0] => Array (
          [id] => 0 
          [titre_dvd] => titre1 
          [rea_dvd] => reaA 
          [avis_dvd] => 1
       ) 
       [1] => Array ( 
          [id] => 2 
          [titre_dvd] => titre3 
          [rea_dvd] => reaC 
          [avis_dvd] => 2
       ) 
       [2] => Array ( 
          [id] => 1 
          [titre_dvd] => titre2 
          [rea_dvd] => reaB 
          [avis_dvd] => 4 
       ) 
    )

  16. #16
    Expert éminent sénior
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Points : 16 545
    Points
    16 545
    Billets dans le blog
    12
    Par défaut
    Ah, c'est résolu, tant mieux

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 5
    Dernier message: 04/02/2014, 10h52
  2. [PHP 5.2] Trier un tableau multidimensionnel ?
    Par nazoreen dans le forum Langage
    Réponses: 4
    Dernier message: 04/03/2009, 15h59
  3. Réponses: 7
    Dernier message: 02/07/2008, 16h06
  4. [Tableaux] comment trier un tableau multidimensionnel
    Par tibotibo69 dans le forum Langage
    Réponses: 2
    Dernier message: 26/02/2008, 17h04
  5. [Tableaux] trier un tableau multidimensionnel
    Par chris801 dans le forum Langage
    Réponses: 2
    Dernier message: 08/06/2007, 08h43

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo