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 :

Comparer 2 tableaux


Sujet :

Langage PHP

  1. #1
    Nouveau membre du Club
    Inscrit en
    Mai 2007
    Messages
    80
    Détails du profil
    Informations forums :
    Inscription : Mai 2007
    Messages : 80
    Points : 38
    Points
    38
    Par défaut Comparer 2 tableaux
    Bonjour à tous,

    voila, j'ai une requête suivante :
    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
    // information pour la connection à le DB
    $host = 'localhost';
    $user = 'xxxx';
    $pass = 'xxxx';
    $db = 'yyyyyy';
     
    // connection à la DB
    $link = mysql_connect ($host,$user,$pass) or die ('Erreur : '.mysql_error() );
    mysql_select_db($db) or die ('Erreur :'.mysql_error());
     
    $select = 'SELECT filename FROM documentversion WHERE isinfile="0"';
    $result = mysql_query($select,$link) or die ('Erreur : '.mysql_error() );
    $total = mysql_num_rows($result);
    et le code suivant, pour mettre dans un tableau les noms de fichiers du repertoire courant :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
     
    $dir_nom = '.'; // dossier listé (pour lister le répertoire courant : $dir_nom = '.'  --> ('point')
    $dir = opendir($dir_nom) or die('Erreur de listage : le répertoire n\'existe pas'); // on ouvre le contenu du dossier courant
    $fichier= array(); // on déclare le tableau contenant le nom des fichiers
     
    while($element = readdir($dir)) {
    	if($element != '.' && $element != '..') {
    		if (!is_dir($dir_nom.'/'.$element)) {
    		$fichier[] = $element;
    		}
    	}
    }
    J'aimerais comparer le nom des fichiers stockés dans le tableau $fichier et les nom retournés par ma requête pour effectuer un renommage.

    Par exemple dans mon tableau $fichier, on a le document "Doc.docx" et le nom "Doc.docx" est stocké dans ma base "yyy" et retourné par la requête.

    Merci à ceux qui pourront m'aider !

  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
    Fait plutot l'inverse :
    1 Recolte tes noms de fichiers et les correspondances dans la base.
    2 Parcours tes dossiers en comparant le nom des fichiers avec ce que tu as recolté dans la base.

  3. #3
    Nouveau membre du Club
    Inscrit en
    Mai 2007
    Messages
    80
    Détails du profil
    Informations forums :
    Inscription : Mai 2007
    Messages : 80
    Points : 38
    Points
    38
    Par défaut
    Merci pour ta réponse

    Mais comment procéder pour l'étape 1 ? (en fait, je n'avais pas vu ca dans cet ordre) Je débute en php, donc j'ai encore un peu de mal

  4. #4
    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
    Si j'ai bien compris et que dans ta base tu as filename et une autre colonne avec le nouveau nom :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    $select = 'SELECT filename,autre_colonne FROM documentversion WHERE isinfile="0"';
    $result = mysql_query($select) or die ('Erreur : '.mysql_error() );
    while ($row = mysql_fetch_assoc($result)) {
       $lstFichier[$row['filename']] = $row['autre_colonne'];
    }
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    while($element = readdir($dir)) {
    	if($element != '.' && $element != '..') {
    		if (!is_dir($dir_nom.'/'.$element)) {
    		    if (isset($lstFichier[$element])) {
                              rename($dir_nom.'/'.$element; $dir_nom.'/'.$lstFichier[$element]);
                        }
    		}
    	}
    }

  5. #5
    Nouveau membre du Club
    Inscrit en
    Mai 2007
    Messages
    80
    Détails du profil
    Informations forums :
    Inscription : Mai 2007
    Messages : 80
    Points : 38
    Points
    38
    Par défaut
    Merci pour ta réponse !!

    J'ai adapté ton code suivant ce que je voulais faire et ca marche
    Tu as vu les choses dans l'autre sens et ca m'a bien avancé !
    Merci beaucoup

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

Discussions similaires

  1. [Tableaux] Comparer 2 tableaux à 2 dimensions
    Par lili2704 dans le forum Langage
    Réponses: 3
    Dernier message: 16/11/2007, 14h21
  2. Comparer deux tableaux
    Par gefrey54 dans le forum Powerbuilder
    Réponses: 0
    Dernier message: 12/09/2007, 10h58
  3. [Tableaux] Comparer 2 tableaux
    Par lama85 dans le forum Langage
    Réponses: 3
    Dernier message: 08/08/2006, 15h19
  4. comparer deux tableaux
    Par djibril dans le forum Langage
    Réponses: 4
    Dernier message: 15/11/2005, 15h26

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