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 :

Convertir du texte en opérateur


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Juillet 2012
    Messages
    24
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Bâtiment

    Informations forums :
    Inscription : Juillet 2012
    Messages : 24
    Par défaut Convertir du texte en opérateur
    Bonjour à tous,

    Voilà ma question est relativement simple :
    J'ai créé un userform qui permet à l'utilisateur de rechercher toutes les valeurs d'une feuille en rentrant deux informations : une valeur et un opérateur. Concrètement j'ai une ComboBox avec trois possibilités : = , <= et >= suivie d'une textbox où l'utilisateur peut entrer une valeur.
    Et j'aimerais donc que lorsque l'on clique sur le bouton "OK" la macro compare les valeurs de ma feuille de calcul suivant ces deux critères.
    J'ai rentré le code suivant mais ça ne fonctionne pas (Incompatibilité de type) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    If Range("A1").Value + Comparateur.Value + CInt(Valeur.Value) Then
        MsgBox "C'est bon"
    Else: MsgBox "C'est pas bon"
    End If
    Il s'agit juste d'un code permettant de tester si la concaténation de la valeur de ma combobox (Comparateur) avec une valeur de la feuille et la valeur rentrée par l'utilisateur fonctionne. Et ça ne marche pas.
    J'ai réussi à faire ce que je voulais avec un Select Case mais c'est un peu lourd d'autant que cette condition viendrait idéalement s'ajouter à d'autres dans un grand If donc j'aurais voulu savoir s'il y avait la possibilité de procéder par concaténation.

    Merci d'avance.

  2. #2
    Invité
    Invité(e)
    Par défaut Bonjour,
    à moins de factoriser je ne voies pas! en plus si tu factorises, tu pourra simplifier les testes IF...ELSE.
    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
    Function Compar(V1 As String, Comparateur As String, V2 As String) As Boolean
        Select Case Comparateur
            Case "<"
                If V1 < V2 Then Compar = True
            Case "<="
                 If V1 <= V2 Then Compar = True
            Case "="
                 If V1 = V2 Then Compar = True
            Case "=>"
                 If V1 >= V2 Then Compar = True
            Case ">"
                 If V1 > V2 Then Compar = True
        End Select
    End Function
    Sub TestCompar()
    If Compar(Range("A1").Value, Comparateur.Value, Valeur.Value) = True Then
        MsgBox "C'est bon"
    Else: MsgBox "C'est pas bon"
    End If
    End Sub
    Dernière modification par Invité ; 11/04/2014 à 10h40.

  3. #3
    Expert confirmé Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Par défaut
    Bonjour Robert,
    je mets ce que j'avais préparé :
    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
    Select Case Comparateur
      Case "="
        If Range("A1") = CInt(Valeur) Then
          MsgBox "c'est bon"
        Else: MsgBox "ce n'est pas bon"
        End If
      Case "<="
        If Range("A1") <= CInt(Valeur) Then
          MsgBox "c'est bon"
        Else: MsgBox "ce n'est pas bon"
        End If
      Case ">="
        If Range("A1") >= CInt(Valeur) Then
          MsgBox "c'est bon"
        Else: MsgBox "ce n'est pas bon"
        End If
      End Select
    avec mes excuses
    Cordialement,
    Dom
    _____________________________________________
    Vous êtes nouveau ? pour baliser votre code, cliquer sur cet exemple : Anomaly
    pensez à cliquer sur :resolu: si votre problème l'est
    Par contre, il est désagréable de voir une discussion résolue sans message final du demandeur (satisfaction, désarroi, remerciement, conclusion...)

  4. #4
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Juillet 2012
    Messages
    24
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Bâtiment

    Informations forums :
    Inscription : Juillet 2012
    Messages : 24
    Par défaut
    Super merci beaucoup.
    Je vais factoriser en effet, ça sera plus simple.

    Casefayere : j'ai exactement le même code, à la lettre près ^^

  5. #5
    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
    Utilisation de Evaluate

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    If Evaluate(Range("A1").Value & Comparateur.Value & CInt(Valeur.Value)) Then
        MsgBox "C'est bon"
    Else
        MsgBox "C'est pas bon"
    End If

  6. #6
    Expert confirmé Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Par défaut
    Bonjour à tou(te)s,

    Toujours aussi efficace mercatog, il me semblais qu'il y avais une possibilité, mais à mon aaaaage, on oublie.
    Cordialement,
    Dom
    _____________________________________________
    Vous êtes nouveau ? pour baliser votre code, cliquer sur cet exemple : Anomaly
    pensez à cliquer sur :resolu: si votre problème l'est
    Par contre, il est désagréable de voir une discussion résolue sans message final du demandeur (satisfaction, désarroi, remerciement, conclusion...)

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

Discussions similaires

  1. Convertir du texte formatte en texte
    Par Seth77 dans le forum Langage
    Réponses: 3
    Dernier message: 14/02/2006, 22h53
  2. [MS-DOS] Une commande DOS pour convertir un texte en OEM
    Par Furius dans le forum Autres Logiciels
    Réponses: 1
    Dernier message: 30/12/2005, 19h47
  3. Réponses: 4
    Dernier message: 29/12/2005, 17h51
  4. convertir le text de DBedit vers PAnsiChar ?
    Par _alex_ dans le forum Langage
    Réponses: 2
    Dernier message: 22/12/2005, 14h44
  5. Convertir un texte en OEM avec Notepad++
    Par Furius dans le forum Autres Logiciels
    Réponses: 17
    Dernier message: 17/10/2005, 13h18

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