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 :

Evaluer la valeur d'une variable à partir d'une chaine de caracteres


Sujet :

Macros et VBA Excel

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2011
    Messages
    38
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Mars 2011
    Messages : 38
    Points : 36
    Points
    36
    Par défaut Evaluer la valeur d'une variable à partir d'une chaine de caracteres
    Bonjour,

    Je suis en train de développer un module commun pour différentes macros qui récupère la version de chacun des modules. Celle-ci est stockée dans une constante publique par module.

    Le problème est que le module commun contient toutes les constantes possibles mais dès qu'un module est manquant dans une de mes macros, l'option explicit bloque la compilation.

    Je ne souhaite pas enlever l'option explicit gage de variables correctement déclarées.

    Je cherchais à faire Evaluate("Ma_constante") et gérer l'erreur si celle-ci n'existe pas dans la macro mais ce code ne fonctionne pas.

    Avez-vous une idée sur ce sujet?

    Merci d'avance pour vos réponses constructives.
    Cordialement,
    batseb

  2. #2
    Membre éprouvé
    Profil pro
    Inscrit en
    Juin 2009
    Messages
    652
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juin 2009
    Messages : 652
    Points : 1 219
    Points
    1 219
    Par défaut
    Bonjour,

    Peut être une piste en utilisant une gestion d'erreur.
    Dans le code exemple suivant, le but est de tester l'existence de feuilles et d'envoyer un message pour celles ne l'étant pas.
    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
    Sub aa()
    Dim S As Worksheet
    Dim i&
    Dim MsgErreur$
    Dim MesFeuilles As Variant
    '--- Nom de toutes les feuilles à rechercher---
    MesFeuilles = Array("Feuil3", "zaza", "Feuil1", "toto")
     
    '--- Test de l'existence des feuilles ---
    On Error Resume Next
    For i& = LBound(MesFeuilles) To UBound(MesFeuilles)
      Set S = ActiveWorkbook.Sheets(MesFeuilles(i&))
      If Err <> 0 Then
        MsgErreur$ = MsgErreur$ & MesFeuilles(i&) & vbCrLf
        Err.Clear
      End If
    Next i&
    On Error GoTo 0
    '---
    If MsgErreur$ <> "" Then MsgBox prompt:=MsgErreur$, Title:="Feuile(s) inexistante(s)"
    End Sub
    Vous pouvez adapter cet exemple pour tester l'existence de Modules.

Discussions similaires

  1. Réponses: 4
    Dernier message: 22/02/2012, 18h07
  2. Réponses: 1
    Dernier message: 07/04/2011, 20h28
  3. Réponses: 2
    Dernier message: 13/09/2007, 11h34
  4. Valeur par defaut a partir d'une variable vba ?
    Par Alpha31 dans le forum Access
    Réponses: 2
    Dernier message: 06/06/2006, 16h00
  5. Réponses: 7
    Dernier message: 15/11/2005, 10h14

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