[VBA] Appel dynamique à une procédure
Jef
-
Utilisateur anonyme -
Utilisateur anonyme -
Bonjour tout le monde,
Voici le contexte:
Sous Access 2003, j'ai une 30aine de modules(pas de modules de classe), contenant chacun une procédure appelée "stat()".
Chaque module porte un nom différent et la procédure "stat()" est différente pour chaque module.
J'ai fait ceci pour ne pas avoir 30 procédures différentes dans un meme module. C'est + facile pour retrouver une procédure et la commenter, vu que 1 module = 1 procédure = 1 description de module.
Sur un formulaire, j'affiche les noms de mes modules dans une liste grace a:
Code:
Code :
Une fois le module selectionné dans la liste, je voudrais pouvoir le lancer grace à un bouton
(donc en gros lancer: ZoneListe1.value + ".stat()"
En dur, il suffit de faire: nomDuModule.nomDeLaProcedure
Mais en dynamique, comment faire?
Merci beaucoup de votre aide, pcq la je suis vraiment coincé.
Rem: ceci:
Code :
donne L'erreur d'exécution n° 2517:
MSAccess ne peut trouver la préocédure essai.stat()
Voici le contexte:
Sous Access 2003, j'ai une 30aine de modules(pas de modules de classe), contenant chacun une procédure appelée "stat()".
Chaque module porte un nom différent et la procédure "stat()" est différente pour chaque module.
J'ai fait ceci pour ne pas avoir 30 procédures différentes dans un meme module. C'est + facile pour retrouver une procédure et la commenter, vu que 1 module = 1 procédure = 1 description de module.
Sur un formulaire, j'affiche les noms de mes modules dans une liste grace a:
Code:
Code :
Private Sub Form_Load() Dim db As DAO.Database, mddoc As DAO.Document, strDesc As String Set db = CurrentDb For Each mddoc In db.Containers("Modules" ).Documents ZoneListe1.AddItem (mddoc.Name) Next End Sub
Une fois le module selectionné dans la liste, je voudrais pouvoir le lancer grace à un bouton
(donc en gros lancer: ZoneListe1.value + ".stat()"
En dur, il suffit de faire: nomDuModule.nomDeLaProcedure
Mais en dynamique, comment faire?
Merci beaucoup de votre aide, pcq la je suis vraiment coincé.
Rem: ceci:
Code :
Application.Run(ZoneListe1.value & ".stat()" )
donne L'erreur d'exécution n° 2517:
MSAccess ne peut trouver la préocédure essai.stat()
A voir également:
- [VBA] Appel dynamique à une procédure
- Nommez une application d'appel vidéo ou de visioconférence - Guide
- Tableau croisé dynamique - Guide
- Appel privé - Guide
- Exemple tableau croisé dynamique télécharger - Télécharger - Tableur
- Liste déroulante dynamique excel - Guide
7 réponses
Bonjour,
Voici la syntaxe type d'un bouton appellant :
Ici, c'est bien le nom d'une macro et non le nom d'une procédure. Vous pouvez contourner de deux façon, soit en chargeant les références nécessaires pour manipuler les objets VBA, l'ayant fait sous excel je puis vous dire que c'est lourd et autre soluce un peu moins élégante, vous allez créer une macro pour chaque "procédure" que vous transformé en fonction en modifiant le label "Sub" par "Function".
Dans les propriétés de la macro, choisissé l'option "ExécuterCode" et dans le Nom de la fonction, utiliser l'assistant [ ... ] pour pointer votre fonction, vous verrez tous vos modules et toute fonction s'y ratachant.
ainsi le code du haut fonctionnera puisque pour chaque "procédure" devenu "fonction", il y aura une macro d'appel.
Lupin
Voici la syntaxe type d'un bouton appellant :
Private Sub ExecuterSub_Click() On Error GoTo Err_ExecuterSub_Click Dim stDocName As String stDocName = "Macro1" DoCmd.RunMacro stDocName Exit_ExecuterSub_Click: Exit Sub Err_ExecuterSub_Click: MsgBox Err.Description Resume Exit_ExecuterSub_Click End Sub
Ici, c'est bien le nom d'une macro et non le nom d'une procédure. Vous pouvez contourner de deux façon, soit en chargeant les références nécessaires pour manipuler les objets VBA, l'ayant fait sous excel je puis vous dire que c'est lourd et autre soluce un peu moins élégante, vous allez créer une macro pour chaque "procédure" que vous transformé en fonction en modifiant le label "Sub" par "Function".
Dans les propriétés de la macro, choisissé l'option "ExécuterCode" et dans le Nom de la fonction, utiliser l'assistant [ ... ] pour pointer votre fonction, vous verrez tous vos modules et toute fonction s'y ratachant.
ainsi le code du haut fonctionnera puisque pour chaque "procédure" devenu "fonction", il y aura une macro d'appel.
Lupin
Merci mais cela alors reviens au meme de faire un :
Donc de faire une opération pour chaque module, et c'est ce que je voudrais éviter :(
Private Sub Commande4_Click() Select Case ZoneListe1.Value Case "1ereProcedure" 1ereProcedure.Stat Case "2emeProcedure" 2emeProcedure.Stat end select end sub
Donc de faire une opération pour chaque module, et c'est ce que je voudrais éviter :(
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question