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 :

Opérateur de comparaison dans une variable


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Femme Profil pro
    Météorologiste
    Inscrit en
    Octobre 2010
    Messages
    60
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 37
    Localisation : France, Eure et Loir (Centre)

    Informations professionnelles :
    Activité : Météorologiste
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Octobre 2010
    Messages : 60
    Par défaut Opérateur de comparaison dans une variable
    Bonjour,

    J'ai dans ma cellule A1 un nombre quelconque
    dans ma cellule A2, un opérateur >= ou <= ou =
    dans ma cellule A3 un nombre décimal
    J'aimerais récupérer les valeurs de A2 et A3 et les mettre dans une variable puis via une macro, comparer avec la cellule A1
    exemple :
    A1 : 0,2 A2 : >= A3 : 0,5
    Avec la macro, j'aimerais savoir si 0,2 >= 0,5 sachant que le comparateur dans A2 peut changer à tout moment.

    J'ai essayé :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    Dim operateur As String, seuil As Single
    operateur = range("A2").value
    seuil = range("A3").value
    If range("A1").value & operateur & seuil then
    Range("A1").Interior.ColorIndex = 4
    End if
    Bien sûr, ça n'a pas marché ! Pouvez-vous m'aider svp ?

  2. #2
    Invité
    Invité(e)
    Par défaut
    Bonjour Laguernette

    Il faut utiliser "Evaluate" pour évaluer le résultat d'une formule, voici le code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Sub Test()
      Dim Operateur As String, Seuil As Single
      Dim MaFormule As String
      ' Récupérer les valeurs nécessaires
      Operateur = Range("A2").Value
      Seuil = Range("A3").Value
      ' Définir la formule en remplaçant si nécessaire le séparateur décimal
      MaFormule = Replace(Range("A1"), ",", ".") & Operateur & Replace(Seuil, ",", ".")
      ' Test de la formule
      If Application.Evaluate(MaFormule) Then
        Range("A1").Interior.ColorIndex = 4
      End If
    End Sub
    A+

  3. #3
    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
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Sub Test()
    Dim Op As String
     
    Op = [A2]
    If Evaluate("A1" & Op & "A3") Then
        [A1].Interior.ColorIndex = 4
    Else
        [A1].Interior.ColorIndex = xlNone
    End If
    End Sub

  4. #4
    Membre confirmé
    Femme Profil pro
    Météorologiste
    Inscrit en
    Octobre 2010
    Messages
    60
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 37
    Localisation : France, Eure et Loir (Centre)

    Informations professionnelles :
    Activité : Météorologiste
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Octobre 2010
    Messages : 60
    Par défaut
    Merci pour ces réponses si rapides. ça fonctionne très bien, je ne connaissais pas du tout la fonction "evaluate".
    Un grand merci à vous !

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

Discussions similaires

  1. Stocker un noeud dans une variable
    Par Devotion dans le forum XSL/XSLT/XPATH
    Réponses: 14
    Dernier message: 23/09/2004, 17h02
  2. [Sybase] résultat d'un select dans une variable
    Par stoz dans le forum Sybase
    Réponses: 2
    Dernier message: 14/09/2004, 14h28
  3. Résultat d'une requête dans une variable...
    Par Hoegaarden dans le forum Bases de données
    Réponses: 6
    Dernier message: 28/04/2004, 13h51
  4. Réponses: 6
    Dernier message: 24/07/2003, 12h39
  5. [langage] Extraire un block dans une variable multiligne
    Par |DUCATI| DesMo dans le forum Langage
    Réponses: 9
    Dernier message: 11/02/2003, 14h56

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