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 :

Importer tableau Word vers Excel avec une Macro VBA


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2024
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Vienne (Limousin)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Janvier 2024
    Messages : 2
    Par défaut Importer tableau Word vers Excel avec une Macro VBA
    Bonjour, j'ai plusieurs documents Word mis en page à l'identique. Je souhaite importer les données de tous les tableaux n°3 de chaque Word. Chaque tableau n°3 comporte 4 colonnes et un nombre variable de ligne. J'ai une macro VBA qui fonctionne pour un document mais impossible de le faire sur un dossier contenant tous les word. Avez-vous une solution à m'apporter sur la macro suivante svp ?

    Sub importTableWord_VersExcel()
    '
    ' importTableWord_VersExcel Macro
    '
    'Nécessite d'activer la référence:
    'Microsoft Word xx.x Object Library

    Dim WordApp As Object
    Dim WordDoc As Object
    Dim Tableau As Object
    Dim i As Integer, j As Integer


    'Création instance Word
    Set WordApp = CreateObject("Word.Application")

    'Masque Word pendant l'opération
    WordApp.Visible = False

    'Ouvre le document Word
    Set WordDoc = WordApp.documents.Open("C:\Users\Desktop\Test.docx")

    'Représente le premier tableau dans le document
    Set Tableau = WordDoc.Tables(3)

    'Boucle sur les colonnes de chaque tableau
    For i = 1 To Tableau.Columns.Count

    'Boucle sur les cellules de chaque colonne
    For j = 1 To Tableau.Columns(i).Cells.Count

    'Importe les données du tableau dans la feuille active
    ActiveSheet.Cells(j, i) = Tableau.Columns(i).Cells(j)
    Next j
    Next i

    'Ferme le document Word
    WordDoc.Close False
    'Ferme l'instance Word
    WordApp.Quit

    '
    Application.Goto Reference:="importTableWord_VersExcel"

    End Sub

  2. #2
    Membre Expert
    Inscrit en
    Décembre 2002
    Messages
    993
    Détails du profil
    Informations forums :
    Inscription : Décembre 2002
    Messages : 993
    Par défaut
    Salut, teste ceci, j'ai simplement ajouté une boucle pour parcourir tous les fichiers du dossier:

    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
    Sub importTableWord_VersExcel()
    '
    ' importTableWord_VersExcel Macro
    '
    'Nécessite d'activer la référence:
    'Microsoft Word xx.x Object Library
     
    Dim WordApp As Object
    Dim WordDoc As Object
    Dim Tableau As Object
    Dim i As Integer, j As Integer
    Dim fichier As String
    Dim chemin As String
     
    'Création instance Word
    Set WordApp = CreateObject("Word.Application")
     
    'Masque Word pendant l'opération
    WordApp.Visible = False
     
    'Chemin du dossier contenant les fichiers Word
    chemin = "C:\Users\Desktop\"
     
    'Premier fichier Word dans le dossier
    fichier = Dir(chemin & "*.docx")
     
    'Boucle sur tous les fichiers Word dans le dossier
    Do While fichier <> ""
        'Ouvre le document Word
        Set WordDoc = WordApp.documents.Open(chemin & fichier)
     
        'Représente le premier tableau dans le document
        Set Tableau = WordDoc.Tables(3)
     
        'Boucle sur les colonnes de chaque tableau
        For i = 1 To Tableau.Columns.Count
     
            'Boucle sur les cellules de chaque colonne
            For j = 1 To Tableau.Columns(i).Cells.Count
     
                'Importe les données du tableau dans la feuille active
                ActiveSheet.Cells(j, i) = Tableau.Columns(i).Cells(j)
            Next j
        Next i
     
        'Ferme le document Word
        WordDoc.Close False
     
        'Prochain fichier Word
        fichier = Dir
    Loop
     
    'Ferme l'instance Word
    WordApp.Quit
     
    '
    Application.Goto Reference:="importTableWord_VersExcel"
     
    End Sub

  3. #3
    Nouveau candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2024
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Vienne (Limousin)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Janvier 2024
    Messages : 2
    Par défaut
    Merci pour ta réponse Franc.

    Dans un premier temps il y a eu une erreur pour trouver le chemin du dossier. J'ai ensuite modifier le chemin.
    Il n'y a plus de message d'erreur, la macro s'exécute mais aucunes données n'apparaissent dans excel.

    Je suis novice en VBA, je ne comprends pas d'où peut venir le problème ?

Discussions similaires

  1. Réponses: 8
    Dernier message: 01/04/2021, 19h43
  2. [XL-2016] Tableau word vers Excel (suivant votre macro (Sub importTableWord_VersExcel())
    Par re dans le forum Macros et VBA Excel
    Réponses: 7
    Dernier message: 07/10/2019, 23h58
  3. [XL-2010] Créer un tableau "Bilan" sur EXCEL avec une macro
    Par miamiator dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 09/11/2017, 11h37
  4. Nouveau problème avec un tableau Excel et une macro VBA
    Par valouche dans le forum Macros et VBA Excel
    Réponses: 11
    Dernier message: 30/06/2007, 09h30
  5. Réponses: 2
    Dernier message: 04/06/2007, 15h39

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