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 :

récupérer une variable d'un autre module [XL-2007]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Profil pro
    Étudiant
    Inscrit en
    Décembre 2010
    Messages
    229
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2010
    Messages : 229
    Par défaut récupérer une variable d'un autre module
    Bonjour à tous

    J'aimerai savoir une manière de reprendre une varaible déjà utiliser dans un autre module, je m'explique:

    Je pars d'un formulaire, lorsque je clique sur un bouton une macro s'ouvre

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     Private Sub controle3_Click()
     
    Dim j As Integer
    Feuil1.Select
     
    Call controle_données
    puis j'apelle le module "controle_données"

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    Sub controle_données()
    
    Feuil1.Select
    Dim nb_ligne As Integer
    Dim i As Integer
    Dim n As Integer
    Dim compte_false As Integer
    Dim compte_miss As Integer
    Les deux variables en rouges vont me données 2 nombres, j'aimerai que ces 2 nombres me soit rapportés dans la macro "Private Sub controle3_Click"

    Merci d'avance de vos réponses

  2. #2
    Invité
    Invité(e)
    Par défaut
    Bonjour
    Peut être un peu de lecture sur les variables et leurs portées.
    http://mhubiche.developpez.com/Access/variables/

  3. #3
    Membre éclairé
    Profil pro
    Étudiant
    Inscrit en
    Décembre 2010
    Messages
    229
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2010
    Messages : 229
    Par défaut
    Merci gayot pour ce tuto j'ai appris quelques petit truc

    Malheureusement je n'ai pas réussi à trouver une solution à mon problème

    J'ai essayé de mettre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     Sub controle_données()
    mais je n'arrive pas à appelé la procédure

    Je ne comprend pas comment je dois faire

    Si quelqu'un peut m'aider en me donnant de nouvelles indications de réponse

    Merci d'avance

    D'après le tuto si on veux déclarer les variables il faut mettre public dans la définision de la macro...
    mais ca ne marche pas , pour être franc je ne comprend pas vraiment tout.
    Merci de m'aider

  4. #4
    Expert éminent Avatar de mercatog
    Homme Profil pro
    Inscrit en
    Juillet 2008
    Messages
    9 435
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations forums :
    Inscription : Juillet 2008
    Messages : 9 435
    Par défaut
    Il y a 3 niveaux de portée des variables
    1. variable déclarée à l'intérieur d'une procédure (ou fonction)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Sub Niv1()
    Dim VarNiv1 As Integer
    ....
    La portée de varNiv1 se limite à cette procédure
    2. variable déclarée au début du module de la feuille (par exemple, ou userform, ou Thisworkbook)
    Exemple: Feuil1
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Option Explicit
    Dim VarNiv2 as Integer
     
    Sub Niv2()
    VarNiv2=36
    end sub
    Sub Niv2prim()
    msgbox VarNiv2
    end sub
    La portée de varNiv2 se limite à l'ensemble des procédures du module de la feuille, userform ou Thisworkbook
    3. variables publiques: déclarées en début d'un module public
    Exemple Module1
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Publiv VarNiv3 as integer
    Cette variablme est de portée publique, c'est à dire reconnu dans toutes les procédures de ton classeur

    Mon explication n'est pas aussi fournie comme celle du lien qui vous a été transmis.

    Maintenant, si tu reporte la totalité de ton code, on peut t'orienter de
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Private Sub controle3_Click()
    et de
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Sub controle_données()
    [Edit]http://silkyroad.developpez.com/VBA/LesVariables/
    V. Les niveaux de variables

  5. #5
    Membre éclairé
    Profil pro
    Étudiant
    Inscrit en
    Décembre 2010
    Messages
    229
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2010
    Messages : 229
    Par défaut
    Merci pour ces nouvelles réféences et indications mercatog,
    mais je n'y arrive toujours pas

    j'ai déclarer mes 2 variables en haut du module: avant les autres sub
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    Public compte_miss As Integer
    Public compte_false As Integer
    puis j'écris ma macro:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    Sub controle_données()
     
    Feuil1.Select
    Dim pourcent As Double
    Dim nombre_ligne As Integer
    Dim i As Integer
    Dim n As Integer
    Lorsque je lance le module en mode pas a pas, Les deux variables défini en public marche très bien...

    Cependant lorsque le module est fini il rebascule sur mon premier programme:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Private Sub controle3_Click()
    mais il nerapporte pas les valeurs de compte_false et compte_miss...

    Quelqu'un a t'il une solution?

  6. #6
    Expert éminent Avatar de mercatog
    Homme Profil pro
    Inscrit en
    Juillet 2008
    Messages
    9 435
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations forums :
    Inscription : Juillet 2008
    Messages : 9 435
    Par défaut
    Au lieu de donner les 2 premières lignes de chaque code, mets ton code en entier

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

Discussions similaires

  1. récupérer une variable dans un autre swf
    Par sonico dans le forum Flash
    Réponses: 0
    Dernier message: 04/11/2009, 11h25
  2. Réponses: 4
    Dernier message: 14/05/2007, 13h44
  3. Récupérer une variable d'une boite de dialogue à l'autre
    Par DjSeblaterreur dans le forum C++/CLI
    Réponses: 16
    Dernier message: 07/12/2006, 10h01
  4. [C# 2.0] Récupérer une variable sur une autre fenêtre
    Par herrs dans le forum Windows Forms
    Réponses: 5
    Dernier message: 14/11/2006, 00h24
  5. Récupérer une variable d'une autre classe
    Par Chris33 dans le forum Général Python
    Réponses: 2
    Dernier message: 06/12/2005, 10h45

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