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 :

automatiser les mêmes tâches pour un répertoire de fichiers .txt


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Août 2008
    Messages
    27
    Détails du profil
    Informations forums :
    Inscription : Août 2008
    Messages : 27
    Par défaut automatiser les mêmes tâches pour un répertoire de fichiers .txt
    Bonjour,


    Je dispose de fichiers .txt dans un répertoire se composant tous de la même manière, par exemple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    D,CNIT,,,,,,CNIT La défense,CNIT - LA DEFENSE,,,,,
    C,CAFET,,,,,,Cafétéria ATRIUM,,,,,,
    C,D,,,,,,Bâtiment D,,,,,,
    C,P,,,,,,Bâtiment P Le DOME,,,,,,
    C,PA,,,,,,Bâtiment PA,,,,,,
    C,C,,,,,,Bâtiment C,,,,,,
    C,L,,,,,,Bâtiment L,,,,,,
    C,N,,,,,,Bâtiment Le NAUTILE,,,,,,
    C,F,,,,,,Bâtiment F Le GALION,,,,,,
    Je dois entourer de guillemets sur chaque ligne les chaînes de caractère, le résultat doit donc être de la forme :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    "D","CNIT",,,,,,"CNIT La défense","CNIT - LA DEFENSE",,,,,
    "C","CAFET",,,,,,"Cafétéria ATRIUM",,,,,,
    J'utilise actuellement 2 morceaux de code VBA (trouvés sur ce forum et grâce à l'aide de certains ) pour entourer de guillemets les chaînes de caractère et enregistrer le nouveau fichier en .txt :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    Sub Guillemets()
    Dim c As Range
    For Each c In Sheets("Nom_feuille").Cells.SpecialCells(xlCellTypeConstants)
        c.Replace Chr(34), ""                       'éliminer les doubles quotes existantes
        c.Value = Chr(34) & c.Value & Chr(34)       'pour encadrer le contenu de chaque cellule
    Next c
    End Sub
    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
    Sub ExportTXT()
     
    ' Exportation du fichier au format TXT
     
    MsgBox "Exportation du fichier"
    Dim Ranges As Object, Line As Object, Cell As Object
    Dim StrTemp As String
    Dim Separateur As String
     
    Separateur = ","
    Filename = Application.GetSaveAsFilename(Nom_Fichier, "Text Files (*.txt), *.txt")
    Set Ranges = ActiveSheet.UsedRange
    Open Filename For Output As #1
     
    For Each Line In Ranges.Rows
    StrTemp = ""
    For Each Cell In Line.Cells
     
    StrTemp = StrTemp & CStr _
    (Cell.Text) & Separateur
     
    Next
    Print #1, StrTemp '= " "
    Next
    Close
     
    End Sub
    Est-il possible d'avoir un code VBA qui prend tous les fichiers .txt d'un répertoire? Ceci d'afin de permettre aux utilisateurs de faire cette opération d'une traite et pas fichier par fichier?
    De plus, le 2ème bout de code ci-dessus met également une virgule à la fin de la chaîne de caractère, ce qui n'est pas toujours nécessaire, comment lui préciser de ne pas en mettre une?

    Merci en avance pour votre aide!

  2. #2
    Expert confirmé Avatar de jfontaine
    Homme Profil pro
    Contrôleur de Gestion
    Inscrit en
    Juin 2006
    Messages
    4 756
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Contrôleur de Gestion

    Informations forums :
    Inscription : Juin 2006
    Messages : 4 756
    Par défaut
    Bonjour,

    Ci dessous petit bout de code qui boucle sur chaque fichier d'un répertoire

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    Dim Fso As Object
    Dim FsoRepertoire As Object
    Dim FsoFichier As Object
     
    Set Fso = CreateObject("Scripting.FileSystemObject")
    Set FsoRepertoire = Fso.GetFolder(ThisWorkbook.Path)
     
    For Each FsoFichier In FsoRepertoire.Files

  3. #3
    Membre averti
    Inscrit en
    Août 2008
    Messages
    27
    Détails du profil
    Informations forums :
    Inscription : Août 2008
    Messages : 27
    Par défaut
    Merci jfontaine de la réponse.

    J'obtiens malgré tout toujours une p***** d'erreur "compile error : invalid outside procedure" sur la ligne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Set FsoRepertoire = Fso.GetFolder(C:\boucle)
    Je vais tester un DIR (explication dans la FAQ ), ce sera peut être plus simple!! (une matinée à essayer de comprendre ce "invalid outside procedure" )

  4. #4
    Membre confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Janvier 2004
    Messages
    194
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Janvier 2004
    Messages : 194
    Par défaut
    Je suppose que c'est une faute de ta part de ne pas avoir mis les guillemets !
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Set FsoRepertoire = Fso.GetFolder("C:\boucle")
    Et sinon si ton fichier comporte des ";" au lieu de "," tu peut l'ouvrir comme un fichier CSV et donc le voir organisé dans Excel !

  5. #5
    Membre averti
    Inscrit en
    Août 2008
    Messages
    27
    Détails du profil
    Informations forums :
    Inscription : Août 2008
    Messages : 27
    Par défaut
    Oui oui c'est une faute de ma part quand je l'ai ré-écris, je l'ai bien mis avec des guillemets dans mon code, et j'obtiens toujours la même erreur...

    Le gros inconvénient des fichiers .csv, c'est le rajout de guillement quand on ouvre les fichiers avec le bloc notes (problème récurrent qui revient sur de nombreux forums).

  6. #6
    Expert confirmé Avatar de jfontaine
    Homme Profil pro
    Contrôleur de Gestion
    Inscrit en
    Juin 2006
    Messages
    4 756
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Contrôleur de Gestion

    Informations forums :
    Inscription : Juin 2006
    Messages : 4 756
    Par défaut
    Tu commences par

    Je dois entourer de guillemets sur chaque ligne les chaînes de caractère, le résultat doit donc être de la forme :
    et ensuite
    Le gros inconvénient des fichiers .csv, c'est le rajout de guillement quand on ouvre les fichiers avec le bloc notes (problème récurrent qui revient sur de nombreux forums).
    C'est pourtant ce que tu souhaites faire, non?

Discussions similaires

  1. Réponses: 1
    Dernier message: 11/01/2015, 15h51
  2. Automatiser les \left \right pour les parenthèses
    Par oc_alex86 dans le forum Mathématiques - Sciences
    Réponses: 4
    Dernier message: 13/03/2011, 16h57
  3. Réponses: 3
    Dernier message: 17/02/2009, 14h43
  4. Réponses: 2
    Dernier message: 07/12/2008, 18h12
  5. Est-ce que je peux utiliser les mêmes variables pour javascript et PHP?
    Par sparil dans le forum Général JavaScript
    Réponses: 9
    Dernier message: 01/07/2007, 14h23

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