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

VBA Discussion :

Charger une combobox avec contenu d'une listbox d'un autre fichier word


Sujet :

VBA

  1. #1
    Membre habitué
    Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2007
    Messages
    246
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Février 2007
    Messages : 246
    Points : 191
    Points
    191
    Par défaut Charger une combobox avec contenu d'une listbox d'un autre fichier word
    Bonjour,

    je souhaite charger un combobox avec le contenu d'une listbox qui se trouve dans un autre fichier word, j'ai essayé ceci:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    Set appWrd = CreateObject("Word.Application")
     appWrd.Visible = True
     Set DocWord = appWrd.Documents.Open("C:\Users\m.bignon\Documents\ADEME\Referentiel ADEME_29102013.dotm")
     
     
     cbCible.AddItem (CStr(DocWord.lbGroupe1.Value))
    mais ce code plante sur cette ligne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    cbCible.AddItem (CStr(DocWord.lbGroupe1.Value))
    lbGroupe1 étant à NULL, je souhaite savoir si il y a une autre possibilité pour accèder au contenu de ma listbox.

    Cordialement

  2. #2
    Membre habitué
    Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2007
    Messages
    246
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Février 2007
    Messages : 246
    Points : 191
    Points
    191
    Par défaut
    je viens d'essayer ceci:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    Dim controle As ContentControl
    Dim sourcedoc As Document
     Set sourcedoc = Documents.Open("C:\Users\m.bignon\Documents\ADEME\Referentiel ADEME_29102013.dotm", Visible:=False)
     
     
     For Each controle In sourcedoc.ContentControls
     
     Next
    mais ça ne fonctionne pas non plus. D'autres propositions ?

  3. #3
    Membre habitué
    Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2007
    Messages
    246
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Février 2007
    Messages : 246
    Points : 191
    Points
    191
    Par défaut
    changement de plan, je décide de passer par des signet. Donc, mon fichier source possède des signets à la place de listbox:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    Set appWrd = CreateObject("Word.Application")
     appWrd.Visible = True
     Set DocWord = appWrd.Documents.Open("C:\Users\m.bignon\Documents\ADEME\Referentiel ADEME_30102013.dotm")
     
     lbThExpertise.RowSource = DocWord.Bookmarks("groupe1").Range.Text
    ici non plus ca ne fonctionne pas je vais essayer avec le addItem en parcourant chaque ligne de mon signet groupe1 (1 ligne = 1 item)

  4. #4
    Membre habitué
    Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2007
    Messages
    246
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Février 2007
    Messages : 246
    Points : 191
    Points
    191
    Par défaut
    Et donc, voilà la solution:

    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
     
    Private Sub InitialiseControl()
     
    Dim sFichier, sTmpt As String
    Dim ArGroupe() As String
    Dim ArGroupeSize As Integer
    Set appWrd = CreateObject("Word.Application")
     appWrd.Visible = False
     
     sFichier = Dir("C:\Users\m.bignon\Documents\ADEME\Referentiel ADEME_30102013.dotm")
     Set DocWord = appWrd.Documents.Open("C:\Users\m.bignon\Documents\ADEME\Referentiel ADEME_30102013.dotm", Visible:=False)
     cbTypeContenu.Clear
     
    On Error GoTo Err
     
     If sFichier <> "" Then
       sTmp = Replace(DocWord.Bookmarks("groupe1").Range.Text, Chr(13), ";")
       ArGroupe = Split(sTmp, ";")
       ArGroupeSize = UBound(ArGroupe) - LBound(ArGroupe)
       For i = 0 To ArGroupeSize - 1
         cbTypeContenu.AddItem (ArGroupe(i))
       Next i
     
     End If
     
    'Par défaut la date de péremption se situe 1 an après la date de validation
    dtFinValidite.Value = DateAdd("yyyy", 1, dtDebutValidite.Value)
    tbNbMois.Text = "12"
     
     
     
    Err:
    DocWord.Close
     
    End Sub

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 22/02/2013, 16h58
  2. Réponses: 4
    Dernier message: 30/09/2008, 10h30
  3. Réponses: 3
    Dernier message: 06/02/2008, 23h35
  4. Réponses: 7
    Dernier message: 28/09/2007, 10h51
  5. [VBA-E]Remplir combobox avec contenu d'une feuille Excel
    Par Deejoh dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 07/03/2006, 17h16

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