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

C# Discussion :

Lister les fichiers d'un dossier: optimisation


Sujet :

C#

  1. #1
    Membre Expert

    Homme Profil pro
    Retraité
    Inscrit en
    Novembre 2007
    Messages
    3 535
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Novembre 2007
    Messages : 3 535
    Par défaut Lister les fichiers d'un dossier: optimisation
    Bonjour,

    J'ai écris le code suivant:

    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
     
    sealed class FileSearch
    {
     
        static void GetListFolder(System.Collections.Generic.List<string> files, string directory,
            string extension, bool recurse)
        {
            try
            {
                foreach (FileInfo fileInfo in new DirectoryInfo(directory).GetFiles())
                {
                    if (fileInfo.Extension.Equals(extension))
                    {
                        files.Add(fileInfo.FullName);
                    }
                }
                if (recurse)
                {
                    foreach (DirectoryInfo directoryInfo in new DirectoryInfo(directory).GetDirectories())
                    {
                        GetListFolder(files, directoryInfo.FullName, extension, recurse);
                    }
                }
            }
            catch (Exception)
            {
                // Silent
            }
        }
     
        public static System.Collections.Generic.List<string> GetFiles(string directory, string extension, bool recurse)
        {
            System.Collections.Generic.List<string> getFiles = new System.Collections.Generic.List<string>();
            GetListFolder(getFiles, directory, extension, recurse);
            return getFiles;
        }
     
    }
    ça fonctionne sans problème mais si je tente par exemple de chercher tous les fichiers .txt dans C:\ et ses sous-dossiers, c'est long ....

    Comment je pourrais optimiser ça ?

    Bien sur, une fois optimisé, je mettrai cette recherche dans un thread.

    Papy !

  2. #2
    Membre éprouvé
    Profil pro
    Inscrit en
    Janvier 2009
    Messages
    201
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2009
    Messages : 201
    Par défaut
    Salut,

    Il me semble que tu peux passer des paramètres de recherche à la méthode Directory.GetFiles() notamment une recherche sur le nom des fichiers.
    Par contre je ne me souviens plus si il y a moyen de géré également la récursivité

    Edit: En effet après avoir rapidement regardé il existe une méthode sur DirectoryInfo qui te retourne tout les fichiers avec un format de recherche et une option qui te permet de faire de la récursivité ou non => http://msdn.microsoft.com/en-us/library/ms143327.aspx

    Edit 2: Ton soucis étant l'optimisation, je crains malheureusement que ça reste long... j'avais déjà dû faire une recherche sur tout un disque avec cette méthode (et en incluant les zip -_- ...). Ça peut être long voir même très long, mais je doute qu'il y ai un alternative.

  3. #3
    Membre Expert

    Homme Profil pro
    Retraité
    Inscrit en
    Novembre 2007
    Messages
    3 535
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Novembre 2007
    Messages : 3 535
    Par défaut
    Oui, c'est ce que j'ai utilisé en premier mais ça pose un problème. Voir mon précédent post

    C'est pour ça que j'ai écris ce code.

  4. #4
    Membre Expert Avatar de sisqo60
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Février 2006
    Messages
    754
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Indre et Loire (Centre)

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 754
    Par défaut
    salut,
    j'ai déjà utilisé ça et ça fonctionne très bien et en plus c'est assez rapide.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Directory.GetFiles("CheminDeMonDossier", "*.txt",SearchOption.AllDirectories);
    Mais je crois qu'il se contente de chercher que dans les sous-répertoires mais pas dans les sous-sous-répertoires donc une récursive est certainement à prévoir...

  5. #5
    Membre Expert

    Homme Profil pro
    Retraité
    Inscrit en
    Novembre 2007
    Messages
    3 535
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Novembre 2007
    Messages : 3 535
    Par défaut
    j'ai déjà utilisé ça et ça fonctionne très bien et en plus c'est assez rapide.
    Oui merci mais à nouveau, ça ne fonctionne pas sur certains dossiers.
    Pour l'exemple, essaye les 2 lignes suivantes:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
                string[] list = System.IO.Directory.GetFiles("C:\\", "txt", System.IO.SearchOption.AllDirectories);
                listBox1.Items.AddRange(list);

  6. #6
    Membre Expert Avatar de sisqo60
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Février 2006
    Messages
    754
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Indre et Loire (Centre)

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 754
    Par défaut
    c'est normal il te dis que "system volume information" n'est pas accessible parce que c'est un répertoire system et que tu 'as pas les droits d'acces!!!
    maintanant toi essaye :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    string[] list = System.IO.Directory.GetFiles("c:\\windows", "*.txt",SearchOption.AllDirectories);
         listBox1.Items.AddRange(list);

  7. #7
    Membre Expert

    Homme Profil pro
    Retraité
    Inscrit en
    Novembre 2007
    Messages
    3 535
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Novembre 2007
    Messages : 3 535
    Par défaut
    ça marche très bien sur ton exemple, je suis d'accord, mais ça veut dire que si je veux faire une recherche sur tous les dossiers et sous-dossiers de C: , je ne peux pas. GetFiles ne résoud donc pas mon problème général

  8. #8
    Membre Expert Avatar de sisqo60
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Février 2006
    Messages
    754
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Indre et Loire (Centre)

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 754
    Par défaut
    dans ce cas là tu peux utiliser Directory.getfiles mais seulement sur les répertoires non system.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    DirectoryInfo directory = new directoryinfo(path);
    if (diectory.Attributes != FileAttributes.System)
    {
        //liste en ref de type List<String>
        liste.addRange(Directory.getfiles(path,string.Format("*.{0}",extension),SearchOption.TopDirectoryOnly));
    }
    en récursif bien sur...
    sauf si tu veux balayer aussi les répertoires system...Dans ce cas tu essaye et tu met un try/catch silencieux pour les répertoires qui provoquent cette erreur

  9. #9
    Membre éprouvé
    Profil pro
    Inscrit en
    Janvier 2009
    Messages
    201
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2009
    Messages : 201
    Par défaut
    Je pense que la meilleure solution est celle de sisqo60 (je n'avais pas fait le rapprochement avec ton précédent post dsl...)

    Par contre, comme je le disais déjà avant, si tu balaye tout le disque c:, attend toi a ce que ce soit long quoi qu'il arrive

  10. #10
    Membre Expert Avatar de sisqo60
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Février 2006
    Messages
    754
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Indre et Loire (Centre)

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 754
    Par défaut
    merci DarkHerumor...

  11. #11
    Membre Expert Avatar de sisqo60
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Février 2006
    Messages
    754
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Indre et Loire (Centre)

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 754
    Par défaut
    voila le 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
     
    public static void ListFichiers(string sourceDir, ref List<string> files) 
    {
        DirectoryInfo dir = new DirectoryInfo(sourceDir);
         if (dir.Exists) 
        {
     
            try
     
            {
                foreach (string d in Directory.GetDirectories(sourceDir))
                    ListDir(d, ref files); 
            }
            catch (/*UnauthorizedAccessException*/)
            {
               //gérer ou non l'exception...
            } 
            foreach (string file in Directory.GetFiles(sourceDir)) 
                files.Add(file);
        }
    }
    A appeler comme ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    List<string> files = newList<string>();
    ListDir(@"LeChemin", ref files);

  12. #12
    Membre Expert

    Homme Profil pro
    Retraité
    Inscrit en
    Novembre 2007
    Messages
    3 535
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Novembre 2007
    Messages : 3 535
    Par défaut Le code final
    Merci à tous ...

    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
     
    sealed class FileSearch
    {
     
        static void GetListFolder(List<string> files, string directory, string extension, bool recurse)
        {
            DirectoryInfo directoryInfo = new DirectoryInfo(directory);
            bool ok1 = directoryInfo.Parent == null;
            bool ok2 = (directoryInfo.Parent != null) & ((directoryInfo.Attributes & FileAttributes.System) != FileAttributes.System); 
            if (ok1 | ok2)
                try
                {
                    foreach (FileInfo fileInfo in directoryInfo.GetFiles())
                    {
                        if (fileInfo.Extension.Equals(extension))
                        {
                            files.Add(fileInfo.FullName);
                        }
                    }
                    if (recurse)
                    {
                        foreach (DirectoryInfo _directoryInfo in directoryInfo.GetDirectories())
                        {
                            GetListFolder(files, _directoryInfo.FullName, extension, recurse);
                        }
                    }
                }
                catch (Exception)
                {
                    // Silent
                }
        }
     
        public static List<string> GetFiles(string directory, string extension, bool recurse)
        {
            List<string> files = new List<string>();
            GetListFolder(files, directory, extension, recurse);
            return files;
        }
     
    }

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

Discussions similaires

  1. Lister les fichiers d'un dossier
    Par Mom's dans le forum AWT/Swing
    Réponses: 3
    Dernier message: 20/11/2006, 09h32
  2. [PC] Lister les fichiers d'un dossier
    Par toto_in_th_sky dans le forum Cobol
    Réponses: 2
    Dernier message: 11/09/2006, 18h44
  3. Réponses: 13
    Dernier message: 24/08/2006, 14h05
  4. Lister les fichiers d'un dossier par page
    Par bwatex dans le forum EDI, CMS, Outils, Scripts et API
    Réponses: 2
    Dernier message: 17/08/2006, 20h09
  5. Réponses: 2
    Dernier message: 24/05/2006, 20h29

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