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

Macros et VBA Excel Discussion :

Comment utiliser variable dans Userform et un module


Sujet :

Macros et VBA Excel

  1. #1
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2016
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2016
    Messages : 5
    Par défaut Comment utiliser variable dans Userform et un module
    Bonjour,

    Depuis mon programme VBA dans un module, j'appelle un Userform, je coche la case qui m'intéresse et ça crée une variable dans mon Userform puis je retourne dans mon module avec un "unload me". Mon problème est que la variable ne fonctionne pas dans mon module.. Je pense qu'elle n'est pas reconnaissable.
    Donc si quelqu'un a une idée de comment faire pour retrouver ma variable dans le module je suis preneur!
    Merci

    Yoann

  2. #2
    Expert confirmé Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Par défaut
    Bonjour,
    ça crée une variable dans mon Useform
    qu'appelles-tu variable dans ce cas ?
    Montres ton code car explications imprécises
    Cordialement,
    Dom
    _____________________________________________
    Vous êtes nouveau ? pour baliser votre code, cliquer sur cet exemple : Anomaly
    pensez à cliquer sur :resolu: si votre problème l'est
    Par contre, il est désagréable de voir une discussion résolue sans message final du demandeur (satisfaction, désarroi, remerciement, conclusion...)

  3. #3
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2016
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2016
    Messages : 5
    Par défaut
    Je suis sur mon portable le je vais essayer plus clairement.

    - dans mon Userform je dit par exemple :
    Et quand je fait dans mon module :
    Mon msgbox est vide, j'en conclut que la variable n'est pas reconnu

  4. #4
    Expert confirmé Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Par défaut
    Déjà, utilises-tu "Option Explicit", ensuite ou est déclarée ta variable, dans le même module ?, dans la même procédure ?, en "Public" en haut d'un module quelconque ?, d'ailleurs, est-elle déclarée si, à tout hasard tu n'utilises pas justement "Option Explicit", sans ton code, que te dire ?
    Cordialement,
    Dom
    _____________________________________________
    Vous êtes nouveau ? pour baliser votre code, cliquer sur cet exemple : Anomaly
    pensez à cliquer sur :resolu: si votre problème l'est
    Par contre, il est désagréable de voir une discussion résolue sans message final du demandeur (satisfaction, désarroi, remerciement, conclusion...)

  5. #5
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2016
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2016
    Messages : 5
    Par défaut
    Merci de m'aider,

    Du coup j'ai rajouté "option explicit" avant private sub checkbox_click()
    Et dans mon éditeur VBA j'ai un userform1 dans le dossier feuille et un module1 dans le dossier modules.

    Maintenant, ça me dit que la variable n'est pas déclaré. J'ai déjà fait un bon bout de programme avec des variables et j'ai jamais eu à les déclarer, je comprend pas vraiment.

    Merci

    J'ai regardé du coup j'ai mis "Dim Var as integer" dans le userform1, du coup ça me demande plus de déclarer la variable mais j'ai toujours rien dans ma msgbox

  6. #6
    Expert confirmé

    Homme Profil pro
    Curieux
    Inscrit en
    Juillet 2012
    Messages
    5 169
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Curieux
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Juillet 2012
    Messages : 5 169
    Billets dans le blog
    5
    Par défaut
    Bonjour,

    visiblement, tu ne maîtrise pas les notion de "portée" de variables

    tu as une variable qui a une portée "procédure" ou peut être une portée "Userform1" suivant si tu l'as déclarée dans une procédure où en haut du module du userform

    tu souhaites ensuite interroger sa valeur en dehors du userform, ça ne peut pas marcher

    tu as deux solutions, voici la plus simple : utiliser une variable publique qui sera manipulable partout

    AVANT TOUTE CHOSE, lis et assimile bien ceci : http://silkyroad.developpez.com/VBA/LesVariables/#LV

  7. #7
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2016
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2016
    Messages : 5
    Par défaut
    Super! Ça marche!
    Je te remercie beaucoup!
    Je ne connaissai effectivement pas la notion de mettre en "public" une variable.

  8. #8
    Expert confirmé

    Homme Profil pro
    Curieux
    Inscrit en
    Juillet 2012
    Messages
    5 169
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Curieux
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Juillet 2012
    Messages : 5 169
    Billets dans le blog
    5
    Par défaut
    Cool,

    du coup, voici la seconde méthode possible (et y'en a encore d'autres !)

    la démonstration par l'exemple.

    nous avons deux modules.

    Dans le premier, on écrit cette macro :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Sub MacroModule2(ByVal Valeur As Long)
        MsgBox Valeur
    End Sub
    Cette procédure va donc afficher la "valeur" de la valeur Valeur qu'on passe en paramètre.


    Dans le second module, on écrit cette macro :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Sub MacroModule1()
    Dim i As Long
        i = 1
        Call MacroModule2(i)
    End Sub
    On a une variable dont la portée ne dépasse pas la procédure ... pourtant MacroModule2 affichera bien la valeur de i.

    Cela réside dans le fait qu'on transmet la valeur de la variable, et non la variable elle-même. Ceci grâce au "type de transmission" qui est effectué par valeur (ByVal) et non par référence (ByRef)

    D'ailleurs, si on tente ByRef, on obtiendra une erreur.

    Il est malin VBA, il te laissera pas la possibilité de modifier une valeur "réelle" de la variable au delà de sa portée . Il te laissera simplement la possibilité de manipuler une copie de cette valeur

    Si cela t'intéresse vraiment, il te suffit de prolonger la lecture du lien que je t'ai donné, il y a une partie qui traite du passage par référence et valeur : http://silkyroad.developpez.com/VBA/LesVariables/#LIV

  9. #9
    Membre Expert
    Inscrit en
    Octobre 2010
    Messages
    1 401
    Détails du profil
    Informations forums :
    Inscription : Octobre 2010
    Messages : 1 401
    Par défaut
    Bonjour joe

    Citation Envoyé par joe.levrai Voir le message
    D'ailleurs, si on tente ByRef, on obtiendra une erreur.

    J'ai tenté ByRef et je n'ai pas obtenu d'erreur.

  10. #10
    Expert confirmé
    Avatar de kiki29
    Homme Profil pro
    ex Observeur CGG / Analyste prog.
    Inscrit en
    Juin 2006
    Messages
    6 132
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

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

    Informations forums :
    Inscription : Juin 2006
    Messages : 6 132
    Par défaut
    Salut, commencer par lire et assimiler : Utiliser les UserForm en VBA Excel
    En complément il y aura : Utiliser les contrôles dans un UserForm, en VBA Excel

  11. #11
    Expert confirmé

    Homme Profil pro
    Curieux
    Inscrit en
    Juillet 2012
    Messages
    5 169
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Curieux
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Juillet 2012
    Messages : 5 169
    Billets dans le blog
    5
    Par défaut
    Bonjour,

    Docmarti, tu as raison, et après quelques tests j'ai compris pourquoi.

    Je viens donc d'apprendre que si le type de l'argument passé en paramètre est différent du type spécifié dans la procédure, là on a un échec en passant par ByRef
    j'ai toujours pensé que c'était relatif à la portée ... alors que c'était autre chose.

    Merci du coup

    Après l'identification du problème, ça devient évident en fait.
    Puisque ByRef accès directement à l'adresse de la variable, le paramètre doit être typé de la même manière.
    Par ByVal, lors de la copie de la variable, le type peut être différent ... dès lors que la valeur de la variable transmise est compatible avec le Type du paramètre

    Lors de mes tests, i était bien déclaré en Long, alors que mon paramètre attendu était en Integer
    Quand j'ai posté mon message, j'ai remis le paramètre en Long histoire que ça soit propre ... et voilà le résultat.

  12. #12
    Membre Expert
    Inscrit en
    Octobre 2010
    Messages
    1 401
    Détails du profil
    Informations forums :
    Inscription : Octobre 2010
    Messages : 1 401
    Par défaut
    Ca me fait rigoler cette question de ByRef et ByVal parce que, pendant des années, je n'arrivais pas à me rappeler lequel modifiait la valeur d'origine et lequel ne la modifiait pas. Cette question était académique et inutile car si je ne veux pas modifier une valeur, je n'ai qu'à ne pas la modifier. C'est tout. Je n'ai donc pas besoin de savoir à quoi sert ByRef et ByVal. Ca me fait rigoler car je vois que je ne suis pas le seul à chercher comment utiliser une commande inutile.

    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
    Sub test()
     
    m = 1234
     
    a = m: Call CommentModifierA(a)
     
    a = m: Call CommentNePasModifierA_1(a)
     
    a = m: Call CommentNePasModifierA_2(a)
     
    End Sub
     
    Sub CommentModifierA(a)
     
     a = "La valeur de A dans la procédure appelante est modifiée"
     
    End Sub
     
    Sub CommentNePasModifierA_1(ByVal a)
     
     a = "Bonjour tout le monde"
     
    End Sub
     
    Sub CommentNePasModifierA_2(a)
    'Si je ne veux pas modifier A, je ne le modifie pas.
     b = a
     
     b = "Bonjour tout le monde"
     
    End Sub

  13. #13
    Membre éprouvé
    Homme Profil pro
    Étudiant
    Inscrit en
    Septembre 2015
    Messages
    72
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Septembre 2015
    Messages : 72
    Par défaut
    Le soucis Joe c'est que dans ton exemple, il y a bien une portée procédurale MAIS la première qui définit i n'étant pas fini au moment où tu sollicites la seconde, l'adresse de stockage de i persiste et il n'y a aucun soucis.

    ByRef et ByVal pour moi servent uniquement :
    - ByRef on peut modifier la valeur c'est ce qu'on veut faire souvent, de plus on perd pas de mémoire à stocker via un ByVal (oui le pb mémoire est plus trop d'actu mais reste vrai)
    - ByVal permet de travailler sur la variable en faire un calcul sans influencer les déroulements futur.

    DeathZarakai.

    P.S. : Si je me trompe, n'hésitez pas à me corriger et m'insulter j'apprendrais un truc (c'est mieux que d'être dans l'erreur)

  14. #14
    Expert confirmé

    Homme Profil pro
    Curieux
    Inscrit en
    Juillet 2012
    Messages
    5 169
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Curieux
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Juillet 2012
    Messages : 5 169
    Billets dans le blog
    5
    Par défaut
    Pour moi ton explication tient parfaitement la route, et creuse encore le fossé entre la façon dont je schématisait les choses, et comment en réalité elles se passent

  15. #15
    Invité
    Invité(e)
    Par défaut
    Bonjour,
    Code userform : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    Dim MyVar
    Public Function Chargement(v)
    MyVar=v
    Me.Show vbmodal
    Chargement =MyVar
    End sub
    Private Quite_click()
    Me.hide
    End sub
    Code Module : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    Sub teste()
    Msgbox usfTest.Chargement("toto")
    Unload usfTest
    En sub

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

Discussions similaires

  1. Réponses: 5
    Dernier message: 12/03/2006, 14h38
  2. [XSL] impossible d'utiliser variable dans expression XPATH
    Par pierre.zelb dans le forum XSL/XSLT/XPATH
    Réponses: 2
    Dernier message: 18/01/2006, 07h41
  3. Comment utiliser OpenGL dans un TPanel ?
    Par PCMan dans le forum Composants VCL
    Réponses: 3
    Dernier message: 07/12/2005, 17h48
  4. Comment utiliser Opengl dans Visual Basic 6
    Par fun31 dans le forum OpenGL
    Réponses: 1
    Dernier message: 03/12/2004, 10h17
  5. [CR][VB6] comment utiliser CR dans VB ?
    Par kouassi_denis dans le forum SDK
    Réponses: 2
    Dernier message: 26/01/2004, 16h20

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