Précédent   Forum des professionnels en informatique > Logiciels > Microsoft Office > Excel > Macros et VBA Excel
Macros et VBA Excel Vos questions relatives aux macros Excel, à l'utilisation de VBA et à l'automatisation de vos classeurs Excel.
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 11/10/2011, 00h31   #1
Invité de passage
 
Inscription : octobre 2011
Messages : 3
Détails du profil
Informations forums :
Inscription : octobre 2011
Messages : 3
Points : 0
Points : 0
Par défaut Membre de méthode ou de données introuvable

bonsoir

j'en viens a poser cette question sur ce forum car je désespère a ne pas trouver la réponse a une chose si banale

voici mon code source :

Code :
1
2
3
4
5
6
7
8
9
Private Sub CommandButton9_Click()
 
Dim Ctrl As Control
 
'Boucle sur la collection de contrôles
For Each Ctrl In Me.Controls
    MsgBox Ctrl.Name
Next Ctrl
End Sub

mais ca bloque a la compilation sur le .Controls

me manque-t-il une référence (MF2.0 Object library est coché ou autre chose ?

merci de vos réponses

Fab
alpin38 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 11/10/2011, 12h10   #2
Membre Expert
 
Avatar de Jean-Pierre49
 
Homme J-Pierre Catherine
Conception Calcul
Inscription : juillet 2007
Messages : 659
Détails du profil
Informations personnelles :
Nom : Homme J-Pierre Catherine
Âge : 57
Localisation : France, Maine et Loire (Pays de la Loire)

Informations professionnelles :
Activité : Conception Calcul
Secteur : Industrie

Informations forums :
Inscription : juillet 2007
Messages : 659
Points : 1 856
Points : 1 856
Bonjour


fait un essais avec :
dans un module
Code :
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
 
Option Explicit
                        Public Init                     As Boolean
Sub BoucleSurControle()
                        Dim Ctrl                    As Control
                        Dim WB                      As Workbook
                        Dim VBComp                  As VBComponent
                        Dim Uf                      As Object
Init = True
 
    Set WB = ThisWorkbook ' instance du classeur
 
    For Each VBComp In WB.VBProject.VBComponents
        If VBComp.Type = 3 Then ' si c'est un Usf
            On Error GoTo Echappe:
            Set Uf = UserForms.Add(VBComp.Name) ' instance de la variable Uf
 
            For Each Ctrl In Uf.Controls ' on boucle sur les contrôles de l'USF
                MsgBox = VBComp.Name & "-" & Ctrl.Name
            Next Ctrl
 
            DoEvents
            Unload Uf
        End If
    DoEvents
Echappe:
    Next VBComp
 
Init = False
 
End Sub
et dans chaque Userform

Code :
1
2
Private Sub UserForm_Initialize()
If Init Then Exit Sub



Cela devrait te donner le nom de l'USF et le nom du contrôle
à adapter après selon tes besoins

Bon courage
__________________
Jean-Pierre Pensez à Voter pour les réponses qui vous ont aidés, d'avance merci
---------Et n'oubliez pas de mettre : ..quand c'est le cas !---------
Jean-Pierre49 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 11/10/2011, 13h03   #3
Expert Confirmé
 
Homme Philippe
ex Observeur CGG / Analyste prog.
Inscription : juin 2006
Messages : 1 706
Détails du profil
Informations personnelles :
Nom : Homme Philippe
Localisation : France, Finistère (Bretagne)

Informations professionnelles :
Activité : ex Observeur CGG / Analyste prog.

Informations forums :
Inscription : juin 2006
Messages : 1 706
Points : 3 627
Points : 3 627
Salut, quel est le message d'erreur ? car perso ton code fonctionne sans problemex
__________________
Pensez à Voter, d'avance merci. ( Pouces en bas à la droite de Citer )
Balisez votre code après l'avoir indenté sous Excel via Smart Indenter
Autre utilitaire : MZ Tools 3.0 VBA

Contribution : Excel / Word / PDF avec Adobe Acrobat Pro / PDFCreator 1 2
kiki29 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 11/10/2011, 18h29   #4
Invité de passage
 
Inscription : octobre 2011
Messages : 3
Détails du profil
Informations forums :
Inscription : octobre 2011
Messages : 3
Points : 0
Points : 0
Citation:
Envoyé par kiki29 Voir le message
Salut, quel est le message d'erreur ? car perso ton code fonctionne sans problemex
salut

le message d'erreur est ce que j'ai mis dans le titre

"Membre de methode ou de données introuvable"


@JP merci de ta réponse , mais le pbm seras le meme avec to code , c'est le ".Controls" qui me génerent une erreur , le code lui fonctionne correctement (c'est une source MS)
alpin38 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 11/10/2011, 20h52   #5
Invité de passage
 
Inscription : octobre 2011
Messages : 3
Détails du profil
Informations forums :
Inscription : octobre 2011
Messages : 3
Points : 0
Points : 0
voici la solution en VBA

Code :
1
2
3
4
5
6
7
8
9
Private Sub CommandButton9_Click()
 
Dim Ctrl As OLEObject
 
'Boucle sur la collection de contrôles
For Each Ctrl In Me.OLEObjects
    MsgBox Ctrl.Name
Next Ctrl
End Sub
alpin38 est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 02h44.


 
 
 
 
Partenaires

Hébergement Web