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 :

Utilisation des opérateurs greater, lower, equal suivant une string [Toutes versions]


Sujet :

Macros et VBA Excel

  1. #1
    Membre actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2012
    Messages
    23
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Juin 2012
    Messages : 23
    Par défaut Utilisation des opérateurs greater, lower, equal suivant une string
    Bonjour,

    J'ai un petit souci de syntaxe.
    Je souhaiterai en fait avoir une liste déroulante avec "<", ">", "=", "<=", ">=" , "<>", et ensuite récupérer le résultat pour effectuer un calcul.

    En gros, je voudrais quelque chose qui me permet de faire :
    if valeur1 ComboBox.value valeur2 then ....

    Mon problème est donc de transformer cette string en opérateur. J'ai essayé quelque chose comme ça, mais je me doutais bien que ça ne marcherait pas.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Sub test()
      Dim operat As XlFormatConditionOperator
      operat = xlEqual
      if 12 operat 12 then
        Debug.Print "OUAIIIIIIS"
      Else
        Debug.Print "Ohhhhhh!"
      End If
    End Sub
    Je suis preneur de toute idée !

  2. #2
    Membre chevronné
    Inscrit en
    Décembre 2003
    Messages
    434
    Détails du profil
    Informations forums :
    Inscription : Décembre 2003
    Messages : 434
    Par défaut
    Salut,

    Peut etre comme ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Sub test()
      Dim operat As String
      operat = "<="
      If Evaluate(13 & operat & 15) Then
        Debug.Print "OUAIIIIIIS"
      Else
        Debug.Print "Ohhhhhh!"
      End If
    End Sub

  3. #3
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Août 2012
    Messages
    30
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Août 2012
    Messages : 30
    Par défaut
    Méthode un peu longue à écrire mais qui marchera sans problème dans ton cas :

    Utilise un Case :

    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
     
    Sub toto
     
    Select Case operateur  'oéprateur est un string
        Case ">"
            If value 1 > value 2 then
                'mettre le truc à faire ici'
            End if
        Case "<"
            If value 1 < value 2 then
                'mettre le truc à faire ici
            End if
    End Select
     
    End Sub
    J'ai été confronté au même problème que toi hier et comme j'ai pas réussi, j'ai fait comme ceci. Donc si tu trouves un truc, n'hésite pas à poster car ça m'intéresse

  4. #4
    Membre actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2012
    Messages
    23
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Juin 2012
    Messages : 23
    Par défaut
    Merci Minick, c'est exactement ce que je voulais !
    Je connaissais pas la fonction Evaluate, mais c'est magique, je vais me renseigner dessus.
    En plus ta méthode est encore mieux que celle de créer un type Operator.

    Merci FanTasTik, mais je ne voulais justement pas utiliser de switchcase, parce que l'on essaie d'optimiser le code et la vitesse d'execution, et les cases sont pas top:
    http://fordom.free.fr/tuto/OPTIMISATION.htm

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 04/12/2009, 15h34
  2. Réponses: 1
    Dernier message: 22/11/2007, 23h52
  3. Réponses: 3
    Dernier message: 02/07/2007, 18h32
  4. Problème d'utilisation des attributs width et height avec une image distante
    Par Ptit_Mouss dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 21/09/2006, 16h40
  5. [SQL] Utilisation des opérateurs SQL plutôt que PHP
    Par php_newbie dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 12/05/2006, 12h38

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