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 alphabétique


Sujet :

Langage PHP

  1. #1
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Mai 2009
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2009
    Messages : 2
    Points : 1
    Points
    1
    Par défaut Tri alphabétique
    Bonjour, je n'arrive pas à afficher les "Directories" par ordre alphabétique alors que les "Virtual Directories" eux s'affiche dans l'ordre:
    voici la fonction concernée:
    merci pour votre aide !

    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
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    function getFolder($path){
    	global $database, $dateFormat, $json;
     
    	userPermissions();
    	$path = mysql_escape_string($path);
     
    	// For Virtual Directories
    	if($path == '' || $path == '/'){
     
    		$query = sprintf('select * from %spermissions inner join %sbins on %spermissions.binid=%sbins.id where userid="%s" and %sbins.name ="%s" order by display',
    						$GLOBALS['tablePrefix'],
    						$GLOBALS['tablePrefix'],
    						$GLOBALS['tablePrefix'],
    						$GLOBALS['tablePrefix'],
    						$_SESSION['userid'],
    						$GLOBALS['tablePrefix'],
    						$_SESSION['user']);
     
    		$result = mysql_query($query,$database) or die( error('Get Folder query failed') );
     
    		while($bins = mysql_fetch_assoc($result)) {
    			$listing[] = array(  displayname => $bins['display'],
    										scheme => $bins['scheme'],
    										type => "directory",
    										name => $bins['name'],
    										path => '/'. $bins['name'],
    										virtual => "true" );
    		}				
     
    		$query = sprintf('select * from %spermissions inner join %sbins on %spermissions.binid=%sbins.id where userid="%s" and %sbins.name !="%s" order by display',
    						$GLOBALS['tablePrefix'],
    						$GLOBALS['tablePrefix'],
    						$GLOBALS['tablePrefix'],
    						$GLOBALS['tablePrefix'],
    						$_SESSION['userid'],
    						$GLOBALS['tablePrefix'],
    						$_SESSION['user']);
     
    		$result = mysql_query($query, $database) or die( error('Get Folder query failed') );
    		$vdcount = mysql_num_rows($result);
     
    		switch(true) {
    			case ($vdcount >= 1):
    				$virtual = "closed";
    				break;
    			case ($vdcount == 1):
    				$virtual = "true";
    				break;
    			default :
    				$virtual = "false";
    		}
     
    		if($vdcount > 0)
    			while($bins = mysql_fetch_assoc($result)){
    				$listing[] = array(  displayname => $bins['display'],
    											scheme => $bins['scheme'],
    											type => "directory",
    											name => $bins['name'],
    											path => '/'. $bins['name'],
    											virtual => $virtual );
    			}
     
    		echo $json->encode($listing);
    		exit;
    	}
     
     
    	// Non Virtual Directories
    	if( getUserAuth('view', $path) ){
    		logAction('list',$path);
    		$fullpath = getUserPath($path).$path;
    		databaseSync($fullpath,$path);
     
    		// Directories
    		if (is_dir($fullpath)) {
    			if ($dh = opendir($fullpath)) {
    			   while (($file = readdir($dh)) !== false) {
    			     if(substr($file,0,1) != '.' && is_dir($fullpath . '/' . $file)) {
    						$listing[] = array( 
    									type => "directory", 
    									name => $file, 
    									path => $path .'/'. $file );
    				  }
    			   }
    			   closedir($dh);
    			}
    		}
    		else error("directory doesnt exist $fullpath");
     
    		// Files
    		$query = sprintf('select *,date_format(`date`,"%s") as `dateformatted` from %sfilesystem where path="%s" and status="%s" order by `filename',
    								$dateFormat,
    								$GLOBALS['tablePrefix'],
    								$fullpath,
    								"found" );
     
    		$result = mysql_query($query,$database) or die( error('Get Folder query failed') );
    		while($files = mysql_fetch_assoc($result)) {
    			$listing[] = array(	type => "file",
    										name => $files['filename'],
    										date => $files['dateformatted'],
    										id => $files['id'] );
    		}
     
    	}
    	else error("Access Denied $path");
     
    	echo $json->encode($listing);
    	exit;
    }

  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
    Bonjour et bienvenu sur le forum,

    Tu peux faire construire un tableau temporaire avec le nom de dossier comme index :
    $listing_nonvirtual[$file] = array ....
    puis le trier avec ksort()

    tu n'as plus ensuite qu'a ajouter le resultat au reste de ton tableau.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Mai 2009
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2009
    Messages : 2
    Points : 1
    Points
    1
    Par défaut
    Citation Envoyé par sabotage Voir le message
    Bonjour et bienvenu sur le forum,

    Tu peux faire construire un tableau temporaire avec le nom de dossier comme index :
    $listing_nonvirtual[$file] = array ....
    puis le trier avec ksort()

    tu n'as plus ensuite qu'a ajouter le resultat au reste de ton tableau.
    merci pour ton accueil et aussi pour ta réponse ultra rapide !, je suis débutant en php en clair je ne comprends pas ta solution à 100% mais je vais chercher.
    Cette fonction vient d'une version abandonnée du merveilleux "Relay File Manager" que l'ont peux trouver sur le svn d'ecosmear.

    SVN repository now available @ svn://svn.ecosmear.com/ecosmear/relay/
    J'ai donc téléchargé cette Version 1.1 (development) résolu la plupart des bugs afin de rendre cette version fonctionnelle, mais il en reste encore quelques détails à régler.
    Si ça intéresse quelqu'un, contactez moi.

Discussions similaires

  1. Tri alphabétique d'un TreeMap dont les clés sont des String
    Par Djakisback dans le forum Collection et Stream
    Réponses: 6
    Dernier message: 31/03/2006, 14h33
  2. Tri alphabétique sur plusieurs champs
    Par lamoufle dans le forum Requêtes
    Réponses: 8
    Dernier message: 04/12/2005, 04h26
  3. [VC++6][MFC]Tri alphabétique dans CEdit
    Par ben_popcorn dans le forum MFC
    Réponses: 5
    Dernier message: 03/10/2005, 09h39
  4. [JTable] tri alphabétique
    Par clairette dans le forum Composants
    Réponses: 1
    Dernier message: 27/07/2005, 11h09
  5. tri alphabétique dans un tableau deux dimensions
    Par *!!cocco!!* dans le forum Algorithmes et structures de données
    Réponses: 7
    Dernier message: 06/12/2004, 21h38

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