[VBA] Lien Excel-Word +

Résolu
Clem -  
pijaku Messages postés 13513 Date d'inscription   Statut Modérateur Dernière intervention   -
Bonjour,

Pour expliquer un peu mon projet, je cartographie un certains nombre d'équipement au sein d'une usine, j'ai donc des schémas sous word (oui bizarre je sais mais on me les a fournis comme ca...) que j'ai découpé en zones à l'aide de zones de textes, et que j'aimerais afficher lorsque l'on cherche un équipement spécifique. J'ai donc une macro sous excel déterminant cette zone, reste maintenant à faire le lien entre ces documents... Désolé si je parais flou...

Je me pose donc deux questions:
- mon excel me renvoi la zone sous la forme: "numéro de zone" espace "nom du document word". Est-il possible de dissocier ces derniers sous VBA? Par exemple permettre de sélectionner ce qu'il y a avant l'espace et ce qu'il a après?
- Comment activer une zone de texte sous word en utilisant une macro sur un fichier excel?

Merci!
Cordialement,
Clem

9 réponses

Résumé de la discussion

Dissocier via VBA une chaîne 'numéro de zone' et 'nom du document', puis activer une zone de texte Word à partir d'un fichier Excel, constitue la problématique centrale. Les solutions proposées pour extraire la partie avant et après l'espace utilisent Split ou Left et Instr, et l'ouverture de Word via une référence Word Object Library dans Excel. La solution complète décrit un module qui ouvre Word, liste les signets représentant les zones dans NomZones, puis demande à l’utilisateur de sélectionner une zone et active le signet. Des conseils pratiques ajoutent l’activation de la référence Word, la gestion des processus et des extensions, pour éviter les erreurs OLE et assurer une interaction fiable.

Généré automatiquement par IA
sur la base des meilleures réponses
  1. pijaku Messages postés 13513 Date d'inscription   Statut Modérateur Dernière intervention   2 773
     
    Bonjour Clem,
    Pas évident tout cela. Les termes utilisés dans ton sujet ne sont pas super explicite, mais c'est normal, on a toujours du mal à exprimer son problème de façon claire et simple...
    Cependant, pas de souci, on va essayer.

    Tu veux :
    1- dissocier, via VBA, une chaine de type "String" séparée par un espace.
    Plein de solutions :
    ==> avec Split :
    Dim maVar As String, Numero, NomDoc
    maVar =  "NuméroDeZone NomDuDocumentWord"
    Numero = Split(maVar, " ")(0)
    NomDoc = Split(maVar, " ")(1)

    ==> avec Left, Right, Len et Instr
    Dim maVar As String, Numero, NomDoc
    maVar =  "NuméroDeZone NomDuDocumentWord"
    Numero = Left(maVar, InStr(maVar, " ") - 1)
    NomDoc = Right(maVar, Len(maVar) - InStr(maVar, " "))

    Left = Gauche, Right = SDroite et Instr(maVar, " ") indique l'emplacement d'un éventuel espace dans maVar.

    2- Comment activer une zone de texte sous word en utilisant une macro sur un fichier excel?
    Qu'entends tu exactement par "activer"?
    parce qu'en fait tu dis :
    à l'aide de zones de textes, et que j'aimerais afficher
    afficher? activer? ou? quand? comment? pourquoi?
    0
  2. Clem
     
    Bonjour pijaku!

    Tout d'abord merci de me consacrer de ton temps :)

    Ta technique du split est tout bonnement magique!

    J'avoue que je ne suis pas très clair... En fait, je souhaite afficher la zone correspondant à "Numero" de la question précédente à l'écran, donc je pensais qu'en la sélectionnant le fichier word serait ouvert directement sur la page où elle se situe... Histoire de faciliter la recherche et ne pas devoir parcourir tout le document à la recherche de cette zone de texte.

    Cordialement,
    Clem
    0
    1. pijaku Messages postés 13513 Date d'inscription   Statut Modérateur Dernière intervention   2 773
       
      En clair, tu veux ouvrir le document Word à la page ou figure ta zone de texte?
      ça me semble difficile s'il n'y a pas d'ancre de définit dans ton doc word.

      On pourrait peut être :
      - ouvrir ton doc word,
      - copier la bonne zone de texte,
      - la coller dans une autre feuille de ton classeur excel.

      Tu dis, on peux essayer les deux manières...
      0
    2. Clem
       
      En fait j'ai un énorme schéma assez complexe (qui tient plus du dessin que du schéma d'ailleurs) qui est un plan de mon usine. Donc dans mon document word, il n'y a que des objets, et très peu de texte. Les zones de texte que j'ai rajouté ne servent qu'a "délimiter" les endroits interessants, c'est pour celà que je voulais pouvoir les afficher.
      Donc les importer sous excel n'apporterait rien a mon problème, malheureusement d'ailleurs si tu dis qu'il est plus facile de faire celà, étant donné que c'est dans l'ensemble du plan que la zone est interessante pour s'y retrouver...
      Désolé d'être si embêtant
      0
    3. Clem
       
      Ou peut-être simplement réussir à déterminer la page suffirait-il, tant que ca permet une recherche plus rapide de la zone :)
      0
  3. Clem
     
    Alors j'ai certaines pages (mais très peu et celà dépend du document word) sur lesquelles il n'y en a pas, d'autres ou il y en a une dizaine... J'avais dans l'optique de créer un objet ActiveX pour leur donner un nom précis genre "zone1" afin de les manipuler sous VBA. Je sais pas si ca fonctionne
    0
    1. pijaku Messages postés 13513 Date d'inscription   Statut Modérateur Dernière intervention   2 773
       
      je regarde la meilleure solution avant que tu ne modifies ton doc word.
      Pour moi ce devrait être des "bookmark", mais je préfères vérifier...
      Bouges pas je reviens
      0
    2. Clem
       
      Je suis tout ouie :)
      0
  4. pijaku Messages postés 13513 Date d'inscription   Statut Modérateur Dernière intervention   2 773
     
    A FAIRE :
    DANS TON DOC WORD :
    Au niveau de toutes tes zones de texte, en fait, à chaque endroit ou tu désires accéder dans ton document word :
    - clic gauche pour placer le curseur à l'endroit exact souhaité
    - Insertion/Signet
    - Nom du signet : mettre un nom explicite qui te permettra de savoir à quel endroit tu te trouves, juste en regardant ce nom...
    Fait cette opération pour tous les endroits auxquels tu souhaites accéder...

    DANS LE CLASSEUR EXCEL :
    - ALT+F11, Outils/Références, cocher la référence : Microsoft word xx.x 0bject Library
    xx.x dépends de ta version d'Excel. pour 2003 : Microsoft word 11.0 0bject Library

    Je reviens dans 5 minutes avec le code VBA à placer dans ton classeur Excel.
    0
  5. Vous n’avez pas trouvé la réponse que vous recherchez ?

    Posez votre question
  6. pijaku Messages postés 13513 Date d'inscription   Statut Modérateur Dernière intervention   2 773
     
    Le code, à insérer dans un module du classeur excel :
    AVANT DE LANCER LA PROCEDURE, BIEN LIRE LES COMMENTAIRES!!!
    Option Explicit 
    
    Sub OuvreWordALaBonnePage() 
    'http://excel.developpez.com/faq/?page=Word 
    '------------- !!! IMPORTANT !!! ---------------- 
    ' 
    '-- nécéssite d'activer la reference : 
    '    'Microsoft word xx.x 0bject Library -- 
    ' 
    '-- Sous VBE : Outils/Références cocher : 
    '    'Microsoft word xx.x 0bject Library 
    ' 
    '------------------------------------------------ 
    
    Dim Appli As Word.Application, WordDoc As Word.Document, BookM As Variant 
    Dim Cpt As Integer, NomZone As String, Chemin As String, NomDoc As String 
    Dim SelectZone As Range, Wbk As Workbook 
    
    '----- partie sous le classeur Excel ------- 
    Set Wbk = ThisWorkbook 
    Chemin = ThisWorkbook.Path  'Valable si le fichier word est dans le même répertoire 
                                'que le classeur excel 
                                'à remplacer par ex : Chemin = "C:\User\Mes documents" 
                                'Chemin est le chemin d'accès complet au doc word 
                                'sans "\" à la fin ET sans le nom du document!! 
                                'ça c'est pas bon : "C:\User\Mes documents\" 
                                'ça non plus : "C:\User\Mes documents\Doc1.doc" 
    NomDoc = "Doc1.doc" '------------A ADAPTER : le nom de ton doc word 
    
    'Si dans le classeur, il existe une feuille appelée "NomZones" Alors 
    If FeuilleExiste(ThisWorkbook, "NomZones") Then 
        'On supprime tout ce qu'elle contient 
        With Sheets("NomZones") 
            .Activate 
            .Cells.Clear 
        End With 
    '---------------------- Si elle n'existe pas 
    Else 
        '------------------ on la créé 
        Sheets.Add 
        ActiveSheet.Name = "NomZones" 
    End If 
    
    '----- partie ouverture ou pas du doc word ------ 
    On Error Resume Next 
    Set Appli = GetObject(, "Word.Application") 
    Set WordDoc = Appli.Documents(Chemin & "\" & NomDoc) 
    On Error GoTo 0 
    's'il est fermé, on l'ouvre 
    If WordDoc Is Nothing Then 
        Set Appli = CreateObject("Word.Application") 
        Set WordDoc = Appli.Documents.Open(Chemin & "\" & NomDoc) 
        Appli.Visible = True 
    End If 
    WordDoc.Activate 
    'on en fait la liste des signets en Feuille "NomZones" du classeur Excel 
    For Each BookM In Word.ActiveWindow.Document.Bookmarks 
        Cpt = Cpt + 1 
        Sheets("NomZones").Cells(Cpt, 1) = BookM.Name 
    Next BookM 
    'On demande à choisir en sélectionnant la bonne cellule 
    Do 
        Set SelectZone = Application.InputBox("Sélectionnez une zone de texte !", "Sélection de cellules", Type:=8) 
    Loop While SelectZone.Value = "" 
    NomZone = SelectZone.Value 
    WordDoc.Activate 
    Cpt = 0 
    For Each BookM In Word.ActiveWindow.Document.Bookmarks 
        Cpt = Cpt + 1 
        If BookM.Name = NomZone Then Exit For 
    Next BookM 
    BookM.Select 
    End Sub 
    
    Function FeuilleExiste(wk As Workbook, stFeuille) As Boolean 
     On Error Resume Next 
     FeuilleExiste = Not (wk.Sheets(stFeuille) Is Nothing) 
    End Function

    Cordialement,
    Franck P
    0
  7. Clem
     
    Merci je teste ca dés maintenant, je te tiens au courant :)
    0
  8. Clem
     
    Je ne comprends pas, malgré le Appli.Visible = True et le WordDoc.Activate, il ouvre bien le document word mais le laisse en arrière plan, donc la ligne:

    For Each BookM In Word.ActiveWindow.Document.Bookmarks

    crash :(
    0
    1. pijaku Messages postés 13513 Date d'inscription   Statut Modérateur Dernière intervention   2 773
       
      Moi aussi, il est en arrière plan, toujours (comprends pas non plus, mais bon). Par contre, ça ne "crashe" pas chez moi...
      Essaye déjà d'enregistrer ton classeur et ton doc, de tout fermer et de rouvrir... On ne sait jamais.
      Ensuite, si cela ne fonctionne toujours pas, remplace :
      For Each BookM In Word.ActiveWindow.Document.Bookmarks 
          Cpt = Cpt + 1 
          Sheets("NomZones").Cells(Cpt, 1) = BookM.Name 
      Next BookM

      par :
      With Word.ActiveWindow
          For Each BookM In .Document.Bookmarks
              Cpt = Cpt + 1
              Sheets("NomZones").Cells(Cpt, 1) = BookM.Name
          Next BookM
      End With

      Les deux fois bien sur...
      0
    2. Clem
       
      Ca le laisse toujours au meme endroit et j'ai le message "commande non disponible: aucun document word n'est ouvert" alors qu'il est en arrière plan certes, mais ouvert quand meme
      0
    3. pijaku Messages postés 13513 Date d'inscription   Statut Modérateur Dernière intervention   2 773
       
      Qu'elle est ta version d'office?
      Ouvres tu au préalable le document word? ou laisses tu tout faire à la macro?
      0
    4. Clem
       
      J'ai la version 2007 de Word et Excel.

      Lorsque le document word est déja ouvert, j'obtiens une erreur OLE, et lorsque je laisse faire la macro, j'obtiens le message précédent
      0
    5. pijaku Messages postés 13513 Date d'inscription   Statut Modérateur Dernière intervention   2 773
       
      erreur OLE sur qu'elle ligne?
      0
  9. seth201 Messages postés 2 Statut Membre
     
    Bonsoir,
    j'ai un petit souci avec excel et word et il me semble que ça ressemble un peu au problème de Clem. Cependant dans mon cas j'ai des graphiques sur Excel sur ces dernier j'ai insérer des zones de textes (pour expliquer certains points remarquables de mes courbes). Le problème c'est que dans mon doc word quand je copie le graph à partir d'excel et que je le colle (de n'importe qu'elle manière) le graph dans son ensemble est copié à part certaines zones de textes.
    0
    1. pijaku Messages postés 13513 Date d'inscription   Statut Modérateur Dernière intervention   2 773
       
      Bonjour,
      Un peu en retard, désolé...

      Alors il faut distinguer les zones de texte inscrite à l'intérieur de ton graph qui elles font parties intégrantes de ton objet graphiques et les zones de texte placées à l'extérieur (ou à cheval entre l'intérieur et l'extérieur) de ton graph qui elles ne font pas parties de ton objet graphique.

      Si tu souhaites copier tous tes objets, y compris les zones de texte, il te faut au préalable les sélectionner. Pour cela, reste appuyé sur Ctrl et, avec ta souris, sélectionne chacun des objets (graph et zones de texte etc...) que tu souhaites copier/coller...
      0
    2. seth201 Messages postés 2 Statut Membre
       
      Merci pour la réponse ça me facilite le travail.
      0
    3. pijaku Messages postés 13513 Date d'inscription   Statut Modérateur Dernière intervention   2 773
       
      de rien, n'hésitez pas.
      a+
      0
  10. pijaku Messages postés 13513 Date d'inscription   Statut Modérateur Dernière intervention   2 773
     
    J'ai un souci sur la sélection.
    As tu une zone de texte par page? plusieurs sur une même page? des pages sans zone de texte?
    Y a t'il un signe distinctif de ces zones de texte? exemple en page 18 la zone de texte comporte le texte : p18 et ceci pour toutes tes zones de texte???
    -1