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 :

Tri après l'utilisation de la fonction "explode"


Sujet :

Langage PHP

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    8
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2008
    Messages : 8
    Points : 5
    Points
    5
    Par défaut Tri après l'utilisation de la fonction "explode"
    Bonjour, dans une fonction je recupere une variable contenant une liste date séparé par une virgule, puis je les trie (croissant).
    Actuellement ce que je fais fonctionne mais je ne sais pas pourquoi et je ne sais pas si c'est bon !! Quelqu'un pourrait-il me le dire :
    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
     
    $debut = explode(',', $debut);
    $debut_count_array = array();
    foreach($debut as $key => $lesdates)
    {
     
    	$debut_count_array[] = $lesdates;
    }
    $debut_count_array = array_count_values($debut_count_array);
     
    ksort($debut_count_array);
     
    foreach ($debut_count_array as $newdebut => $val)
    {
     
    	$query = "INSERT INTO even values ('', '$newdebut', '$id')";
    	sql_query($query) or die(sql_error());
     
    }
    Merci !

  2. #2
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Pourquoi tu reconstruis un tableau a partir de celui obtenu par le explode ?

    Sinon, quel est le format de tes dates ?
    Parce que par exemple "02/01/2009" > "01/02/2009"
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Futur Membre du Club
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    8
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2008
    Messages : 8
    Points : 5
    Points
    5
    Par défaut
    Les dates sont au format anglais 2008/10/04.
    Je suis passé par 2 tableaux parce que je ne suis pas arrivée à faire autrement le tri des dates.

  4. #4
    Membre averti Avatar de Kennel sébastien
    Homme Profil pro
    Développeur
    Inscrit en
    Septembre 2008
    Messages
    226
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Développeur

    Informations forums :
    Inscription : Septembre 2008
    Messages : 226
    Points : 329
    Points
    329
    Par défaut
    Salut

    Essai plutôt:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    <?php
        $debut = explode(',', $debut);
     
        sort($debut);
    ?>

  5. #5
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Ton code me semble vraiment tordu mais je pense qu'il faut surtout se demander pourquoi tu veux inserer des données dans un base dans un ordre précis.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  6. #6
    Futur Membre du Club
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    8
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2008
    Messages : 8
    Points : 5
    Points
    5
    Par défaut
    Parce que les dates sont liées par un numéro et dans une autre requete je fais un group by par rapport à ce numéro et je selectionne le champ date également. Si les dates ne sont pas dans l'ordre souhaité avec le group by ca prend l'id de la derniere date, donc pour que l'affichage soit correcte, les dates doivent etre enregistrées classés
    ------------------
    j'ai essayé comme ca mais ca me marque rien
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
     
    $debut = split($debut, ',');
    sort($tydebut);
     
    foreach ($debut as $val){echo"test : $val<br>";}

  7. #7
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Tu nous mets un pansement sur une jambe de bois

    Il ne faut pas attendre que les donnée dans une base soient ordonnées, sinon comment ajouterait-on des informations ?

    Montre nous plutot ta requete et on verra comment faire pour qu'elle fonctionne independemment de l'ordre des enregistrements.
    Surtout que dans ta base, les données sont au format date donc facile a trier.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  8. #8
    Futur Membre du Club
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    8
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2008
    Messages : 8
    Points : 5
    Points
    5
    Par défaut
    Voila
    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
     
    $result = sql_query("SELECT 
    		uv.topicimage, uv.topictext, 
    		us.id, us.date, us.liaison, 
    		ut.titre, ut.intro, ut.lieu, ut.posteur, ut.groupvoir 
    	FROM 
    		agendsujet uv, 
    		agend us, 
    		agend_dem ut 
    	WHERE 
    		ut.topicid = '$sujet' 
    		AND us.liaison = ut.id 
    		AND ut.valid = '1' 
    		AND us.$cond 
    	GROUP BY us.liaison 
    	ORDER BY us.date DESC LIMIT $start,$nb_news");
    while(list($topicimage, $topictext, $id, $date, $liaison, $titre, $intro, $lieu, $posteur, $groupvoir) = sql_fetch_row($result))
    		{

Discussions similaires

  1. Excel : utilisation de la fonction tri
    Par Hicks90 dans le forum Débuter
    Réponses: 9
    Dernier message: 12/12/2012, 02h04
  2. Réponses: 10
    Dernier message: 22/01/2008, 16h25

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