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 :

Passer une variable dans un module et la récupérer dans un Userform


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de Superpat9999
    Homme Profil pro
    Retraité
    Inscrit en
    Novembre 2003
    Messages
    438
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 77
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Enseignement

    Informations forums :
    Inscription : Novembre 2003
    Messages : 438
    Par défaut Passer une variable dans un module et la récupérer dans un Userform
    Bonjour,
    Je souhaite passer une variable dans un module pour donner la version de mes modifs (déclaration) et lors de l'affichage de mon userform pouvoir récupérer cette variable.
    Code auparavant, lorsque je mettais la version dans une cellule (ce qui n'est guère pratique) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    Private Sub CommandButton2_Click()
    version = Sheets("Données").Range("ZZ99999")
        MsgBox "Version de l'application " & version & ".", vbOKOnly + vbInformation, "VERSION"
    End Sub
    Bonne journée

  2. #2
    Membre Expert
    Femme Profil pro
    Ingénieur
    Inscrit en
    Octobre 2016
    Messages
    1 703
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 30
    Localisation : France, Indre et Loire (Centre)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2016
    Messages : 1 703
    Par défaut
    Bonjour,

    Si je comprends bien, tu veux que ta variable ait une portée au-delà du sub et de ton module?
    Alors il faut la déclarer comme Global. Au début de n'importe lequel de tes modules, tu écris :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Global maVariable As '...
    Ensuite, tu peux utiliser cette variable dans tout ton code dans ce classeur et la variable garde sa valeur pendant toute la durée de l'application.

    Par contre, si tu as besoin de revenir dessus après la durée de l'application, il faut utiliser Static : même principe, en début de module tu écrit
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Static maVariable As '...

  3. #3
    Membre éclairé Avatar de Superpat9999
    Homme Profil pro
    Retraité
    Inscrit en
    Novembre 2003
    Messages
    438
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 77
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Enseignement

    Informations forums :
    Inscription : Novembre 2003
    Messages : 438
    Par défaut
    Merci rialle de me répondre,
    Je déclare ma variable dans mon module principal, mais le problème, c'est que c'est c'est un bouton CommandButton1 qui appelle le Userform (A_Propos) et la commande du bouton (Feuil1) ne passe pas par mes modules mais est dans la feuil1 :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    Private Sub CommandButton1_Click()
        A_Propos.Show
    End Sub
    Nom : excel_1.jpg
Affichages : 3753
Taille : 29,4 Ko

  4. #4
    Membre Expert
    Femme Profil pro
    Ingénieur
    Inscrit en
    Octobre 2016
    Messages
    1 703
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 30
    Localisation : France, Indre et Loire (Centre)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2016
    Messages : 1 703
    Par défaut
    Je ne pense pas que ce soit un problème.
    Tu déclares dans ton module "Module 1", ta variable Global. Tu peux éventuellement l'initialiser à l'ouverture du classeur, puis tu l'utilises quand tu veux.
    J'ai testé ceci :
    Nom : var global.png
Affichages : 3697
Taille : 22,5 Ko
    Avec en plus une initilatisation dans le Workbook :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Sub Workbook_open()
         maVar2 = 1
    End Sub
    Et je n'ai aucun problème.

  5. #5
    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
    Private LaVersion As String
    Public Property Let VERSION(Value As String)
    LaVersion = Value
    End Property
    Public Property Get VERSION() As String
    VERSION = strVERSION
    End Property
    Private Sub CommandButton2_Click()
     MsgBox LaVersion , vbOKOnly + vbInformation, "VERSION"
    End Sub
    Code Module Standard : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Sub test()
    Dim usf As New UserForm1
    usf.VERSION = "Version de l'application " & VERSION & "."
    usf.Show
    End Sub

  6. #6
    Membre Expert Avatar de antonysansh
    Homme Profil pro
    Chargé d'études RH
    Inscrit en
    Mai 2014
    Messages
    1 115
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Chargé d'études RH
    Secteur : Finance

    Informations forums :
    Inscription : Mai 2014
    Messages : 1 115
    Par défaut
    Pourquoi ne pas utiliser la propriété Tag de l'UF.

    Ensuite :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Private Sub CommandButton2_Click()
        MsgBox "Version de l'application " & A_Propos.Tag & ".", vbOKOnly + vbInformation, "VERSION"
    End Sub

  7. #7
    Membre éclairé Avatar de Superpat9999
    Homme Profil pro
    Retraité
    Inscrit en
    Novembre 2003
    Messages
    438
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 77
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Enseignement

    Informations forums :
    Inscription : Novembre 2003
    Messages : 438
    Par défaut
    Merci à tous les 3 pour toutes vos réponses, j'ai tout essayé et tout fonctionne.
    Je ne suis pas trop ferré sur VBA Excel, mais jusqu'à présent, je ne travaillais que dans le Module1, c'est pour cela que je ne voulais modifier que ce module.

    riaolle, pour changer les différentes versions, je suis obligé de modifier ThisWorkbook, qui initialise la variable. Cela fonctionne bien mais je préfère l'option de antonysansh plus simple (mais modification dans l'Userform).
    Quant à la réponse de dysorthographie, il me semble que la version à modifier est dans le Userform, donc peu avantageuse par rapport à l'option de antonysansh.

    Merci à vous et bon week-end

  8. #8
    Membre Expert
    Femme Profil pro
    Ingénieur
    Inscrit en
    Octobre 2016
    Messages
    1 703
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 30
    Localisation : France, Indre et Loire (Centre)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2016
    Messages : 1 703
    Par défaut
    Si ton problème est résolu, n'oublie pas de cliquer sur le bouton
    Bon week-end !

  9. #9
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Août 2010
    Messages
    3 453
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Août 2010
    Messages : 3 453
    Par défaut
    Bonjour,

    Une autre piste, en déclarant Public une variable dans le module de la Form, on y a accès comme pour une propriété ou méthode, avec le point :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    Public Version As String 'en tête de module de la Form
     
    Private Sub UserForm_Activate()
     
        MsgBox "Version de l'application " & Version & ".", vbOKOnly + vbInformation, "VERSION"
     
    End Sub
    pour le bouton :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    Private Sub CommandButton2_Click()
     
        UserForm1.Version = "2.01" 'ici, avec le point
        UserForm1.Show
     
    End Sub

  10. #10
    Invité
    Invité(e)
    Par défaut
    Bonjour,
    question bête et réponse peut être tout autant! comment s'appel ton UserForm?

    Nom : Sans titre.png
Affichages : 3630
Taille : 10,1 Ko

  11. #11
    Membre éclairé Avatar de Superpat9999
    Homme Profil pro
    Retraité
    Inscrit en
    Novembre 2003
    Messages
    438
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 77
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Enseignement

    Informations forums :
    Inscription : Novembre 2003
    Messages : 438
    Par défaut
    Citation Envoyé par dysorthographie Voir le message
    Bonjour,
    question bête et réponse peut être tout autant! comment s'appel ton UserForm?
    Effectivement après verification, j'ai changé le nom et tout refonctionne

    Encore merci, tout est réglé


  12. #12
    Invité
    Invité(e)
    Par défaut
    Vraisemblablement c'est la réponse,,,

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

Discussions similaires

  1. [PHP-JS] Passer une variable PHP->JS dans une boucle
    Par PedroBD dans le forum Langage
    Réponses: 2
    Dernier message: 12/05/2006, 11h43
  2. Passer une variable dans une requête SQL
    Par Remedy dans le forum C++
    Réponses: 2
    Dernier message: 11/05/2006, 16h48
  3. [XSL] Passer une variable a une balise HTML dans un fichier
    Par poseidon2 dans le forum XSL/XSLT/XPATH
    Réponses: 1
    Dernier message: 09/03/2006, 16h39
  4. [VBA]Passer une variable dans une formule Excel
    Par David1974 dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 27/01/2006, 16h52
  5. [Struts] Passer une variable dans l'url
    Par pilz dans le forum Struts 1
    Réponses: 2
    Dernier message: 30/03/2005, 15h23

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