louprovencou
Messages postés6Date d'inscriptionlundi 1 octobre 2007StatutMembreDernière intervention25 janvier 2010
-
10 mai 2008 à 17:12
louprovencou
Messages postés6Date d'inscriptionlundi 1 octobre 2007StatutMembreDernière intervention25 janvier 2010
-
11 mai 2008 à 10:49
Bonjour à tous. Je débute en VBA donc ma question risque de vous sembler évidente mais je galère même aidé de sujets similaires déja postés. Je souhaite simplement qu'en lançant une macro, un Userform apparaisse permettant la saisie dans un TextBox de texte quelconque qui soit affiché dans une cellule A1 (par example) en appuyant sur le bouton OK de l'userform.
Mon code est le suivant:
Dans le module 1:
cs_Jack
Messages postés14006Date d'inscriptionsamedi 29 décembre 2001StatutModérateurDernière intervention28 août 201579 10 mai 2008 à 18:36
Salut
Tu n'as pas saisi le sens de l'argument fourn i avec la méthode Show.
C'est vrai que dans l'aide de Excel, ce n'est pas clair du tout :
Après un Show, on doit préciser vbModal ou vbModeless (et pas False ou True) :
vbModal : Il faudra que la forme ainsi chargée soit déchargée (après le bouton Ok par exemple) pour que le code situé après la commande Show continue.
vbModeless : Les instructions situeés après la commande Show s'exécutent tout de suite.
En pratique et dans ton cas, ta macro doit :
- charger le UserForm
- l'utilisateur doit saisir une donnée puis cliquer sur un bouton Ok
- Recopier le contenu de la TextBox dans une cellule.
Si tu fais cette copie depuis la macro, ça ne marchera pas, quelque soit le mode du Show :
- Si tu utilises vbModal :
La UserForm s'affiche, l'utilisateur saisit son texte et clique sur Ok qui fait fermer la UserForm (à faire)
Quand le programme reprend après la fermeture de la UserForm, elle n'existe plus puisqu'elle vient d'être fermée et le contenu de la TextBox non plus !
- Si tu utilises vbModeless :
La UserForm s'affiche et le programme continue tout de suite en faisant la recopie de la TextBox dans ta cellule.
L'utilisateur n'aura alors encore rien saisi !
Il faut donc que ce soit la UserForm qui écrive la valeur dans ta cellule :
Dans ton Command1 qui, je suppose, est ton bouton Ok, il suffit d'écrire :
Range("A2").Value = UserForm1.TextBox1.Text
et d'ajouter
Unload Me
pour fermer la UserForm.
Côté macro, uniquement cette commande :
UserForm1.Show vbModal
ou
UserForm1.Show vbModeless
La seule chose que cela va changer, c'est que, durant l'affichage de la UserForm, l'utilisateur pourra ou ne pourra pas accéder aux feuilles ou aux menus de Excel. A toi de choisir.
Vala
Jack, MVP VB NB : Je ne répondrai pas aux messages privés
<hr />Le savoir est la seule matière qui s'accroit quand on la partage (Socrate)