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

Macros et VBA Excel Discussion :

Nbre de fichiers et de sous dossiers d'un répertoire [XL-2007]


Sujet :

Macros et VBA Excel

  1. #1
    Membre habitué Avatar de doncamelo
    Homme Profil pro
    Chargé d'études
    Inscrit en
    Décembre 2007
    Messages
    129
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Chargé d'études
    Secteur : Bâtiment

    Informations forums :
    Inscription : Décembre 2007
    Messages : 129
    Points : 164
    Points
    164
    Par défaut Nbre de fichiers et de sous dossiers d'un répertoire
    Bonsoir le forum,

    ça fait une heure que je me bats avec ce code mais sans succès.
    En parcourant la faq et google j'ai trouvé quelques codes permettant de lister les fichiers d'un répertoire et sous répertoires.

    J'ai crée un formulaire pour faciliter l'utilisation.
    Je veux afficher le nbre de sous dossiers et de fichiers du répertoire avant lancement de la procédure (un peu comme lorsqu'on fait un click droit sur un dossier puis propriété).

    J'ai essayé d'adapter le code pour éviter 2 boucles For ... Next, mais j'ai le message d'erreur :

    Erreur de compilation
    Type d'argument ByRef incompatible
    Voici 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
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    Sub lancement()
        Dim NbDossiers&, NbFichiers
     
        'nombre total de dossiers sur le lecteur C
        NbDeFichiersDossiers "C:\TEST\", NbFichiers, NbDossiers
        MsgBox NbDossiers & vbCrLf & NbFichiers
     
    End Sub
     
     
    Sub NbDeFichiersDossiers(DossierRacine$, CpteDossiers&, CpteFichiers&, Optional SousDossiers As Boolean = True)
     
        Dim fso As Object, Dossier As Object
        Dim sousRep As Object
     
        Set fso = CreateObject("Scripting.FileSystemObject")
        Set Dossier = fso.GetFolder(DossierRacine)
     
        CpteDossiers = CpteDossiers + Dossier.SubFolders.Count
        CpteFichiers = CpteFichiers + Dossier.Files.Count
     
        'traitement récursif des sous dossiers
        If SousDossiers Then
            For Each sousRep In Dossier.SubFolders
                NbDeDossiers sousRep.Path, CpteDossiers, CpteFichiers
            Next sousRep
        End If
     
        Set fso = Nothing
     
    End Sub
    Pouvez-vous me dire ce qui ne va pas dans ce code ?

    En pièce jointe vous verrez un peu ce à quoi je veux aboutir

    Merci d'avance
    Fichiers attachés Fichiers attachés

  2. #2
    Expert éminent sénior


    Profil pro
    Inscrit en
    Juin 2003
    Messages
    14 008
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 14 008
    Points : 20 038
    Points
    20 038
    Par défaut
    bonjour,

    tu n'as pas déclaré le type de la varible nbre fichiers rajoute un &

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Dim NbDossiers&, NbFichiers&
    ligne 25 : appel récursif de la fonction, ce n'est pas le bon nom ce devrait être :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
          NbDeFichiers DossierssousRep.Path, CpteDossiers, CpteFichiers

  3. #3
    Membre habitué Avatar de doncamelo
    Homme Profil pro
    Chargé d'études
    Inscrit en
    Décembre 2007
    Messages
    129
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Chargé d'études
    Secteur : Bâtiment

    Informations forums :
    Inscription : Décembre 2007
    Messages : 129
    Points : 164
    Points
    164
    Par défaut
    Bonsoir bbil,

    c impec !!!!
    J'avais trop la tête dans le guidon.

    Merci pour tes remarques

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

Discussions similaires

  1. [SimpleXML] Fichier identique dans sous-dossier diférent.
    Par voxiz dans le forum Bibliothèques et frameworks
    Réponses: 2
    Dernier message: 21/09/2012, 18h52
  2. Réponses: 9
    Dernier message: 13/05/2011, 06h53
  3. Créer un fichier dans un sous-dossier
    Par Biotik dans le forum C++
    Réponses: 2
    Dernier message: 15/07/2010, 10h10
  4. Copier un fichier dans chaque sous-dossier grace a command !
    Par k3vin dans le forum Scripts/Batch
    Réponses: 1
    Dernier message: 26/12/2009, 17h15
  5. Réponses: 4
    Dernier message: 11/12/2007, 12h02

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