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 :

Fonction sort qui me sort un tri mais pas comme je le souhaite : 1 10 11 12 2 3 4 5..


Sujet :

Langage PHP

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    181
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 181
    Points : 78
    Points
    78
    Par défaut Fonction sort qui me sort un tri mais pas comme je le souhaite : 1 10 11 12 2 3 4 5..
    Bonjour,

    J'ai un gros problème...

    J'ai passé toute la journée dessus, je pense arriver vers la fin mais j'ai besoin de vous.

    Je vous explique le problème :

    Nous avons dans une table "photos" un champ "photo" en varchar qu'on ne peut pas changer... car le site a toujours fonctionné avec et plusieurs applications utilisent ce champ.

    J'essaie de classer ces photos mais ce que je fais me classe toujours mal les chiffres.

    Il est de la forme :
    photoid_numero.jpg

    Un exemple :

    Je fais un ORDER BY monchamp ASC, cela m'affiche :

    8_1.jpg
    8_10.jpg
    8_11.jpg
    8_12.jpg
    8_2.jpg
    8_3.jpg
    8_4.jpg
    8_5.jpg
    8_6.jpg
    8_7.jpg
    8_8.jpg
    8_9.jpg

    Il me met toujours le 10, 11, 12... entre le 1 et le 2 !!

    Au lieu de :

    8_1.jpg
    8_2.jpg
    8_3.jpg
    8_4.jpg
    8_5.jpg
    8_6.jpg
    8_7.jpg
    8_8.jpg
    8_9.jpg
    8_10.jpg
    8_11.jpg
    8_12.jpg

    Savez-vous comment faire SVP ???

    J'avais pensé à un tableau mais en faisant la fonction sort, cela me sort toujours dans le même ordre...

    Je vous donne mon code :

    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
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    $query = "SELECT * FROM photos WHERE idphoto='$id' ORDER BY idd DESC";
    $query2 = mysql_query($query) or die(mysql_error());
     
    $tab = array();
     
    while ($a=mysql_fetch_assoc($query2)) {
     
    	$possep=strpos($a['photo'],"_");
     
    	$pospt=strpos($a['photo'],".");
     
    	$lngnum=$pospt-$possep-1;
     
    	$nbpht=substr($a['photo'],$possep+1,$lngnum);
     
    	$faire = $nbpht.", ";
    	$tab[] = $faire;
     
    	//$tab.= ", ".$nbpht;
    	//rsort($tab);
     
     
     
    }
     
    if (is_array($tab)) {
    	sort($tab);
    	foreach ($tab as $value) {
    		echo $value;
    			}
    }

    Pouvez-vous m'aider SVP ???

    Pas facile de se faire comprendre, j'espère que vous aurez compris

    Merci d'avance.

  2. #2
    Modérateur
    Avatar de Bisûnûrs
    Profil pro
    Développeur Web
    Inscrit en
    Janvier 2004
    Messages
    9 868
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Janvier 2004
    Messages : 9 868
    Points : 16 258
    Points
    16 258
    Par défaut
    La fonction te fait un tri alphabétique, ce qui est normal, vu que tu as une chaine de caractères, donc ce n'est pas un tri numérique.

    Tu peux mettre le numéro de tes images (1, 2, 3, ..) en clé de ton tableau et faire un ksort().

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    181
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 181
    Points : 78
    Points
    78
    Par défaut
    Merci pour votre réponse.

    Le ksort m'affiche : 9, 8, 7, 6, 5, 4, 3, 2, 1, 10, 11

    Et je voudrais : 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11

    J'ai dû oublier quelque chose ??

    car je mets bien le numéro de mes images avec ma boucle... Cf. Code ci-dessus puis j'ai aussi mis le ksort...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    if (is_array($tab)) {
    	ksort($tab);
    	foreach ($tab as $value) {
    		echo $value;
    	}
    }
    C'est peut etre parce que je ne les ai pas mis en clé, c'est ça ??
    Comment faut-il faire ???

    Désolé encore mais vous m'aidez beaucoup !

  4. #4
    Modérateur
    Avatar de Bisûnûrs
    Profil pro
    Développeur Web
    Inscrit en
    Janvier 2004
    Messages
    9 868
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Janvier 2004
    Messages : 9 868
    Points : 16 258
    Points
    16 258
    Par défaut
    A la place de faire :
    Il faut faire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $tab[$numerodelimage ] = $faire;
    où $numerodelimage correspond au bon numéro qu'il y a dans le nom de fichier (à toi de l'en extraire).

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    181
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 181
    Points : 78
    Points
    78
    Par défaut
    Super !!!
    Merci, ça fonctionne
    Bonne journée !

  6. #6
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Points : 16 372
    Points
    16 372
    Par défaut
    Alternative à la solution précédente : utiliser natsort
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

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

Discussions similaires

  1. [RegEx] Regex qui fonctionne dans un preg_replace mais pas dans un ereg
    Par méphistopheles dans le forum Langage
    Réponses: 4
    Dernier message: 31/03/2007, 11h56
  2. Menu déroulant qui se déroule sur IE mais pas FF
    Par Webfab dans le forum Balisage (X)HTML et validation W3C
    Réponses: 1
    Dernier message: 10/10/2006, 14h37
  3. Réponses: 4
    Dernier message: 03/05/2006, 00h04
  4. Réponses: 7
    Dernier message: 19/04/2006, 08h54
  5. requette sql qui passe sous oracle 9i mais pas en 8i
    Par maxidoove dans le forum Oracle
    Réponses: 3
    Dernier message: 21/10/2005, 10h59

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