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 :

simplifier une condition If avec or


Sujet :

Macros et VBA Excel

  1. #1
    Membre régulier
    Homme Profil pro
    Inscrit en
    Juillet 2012
    Messages
    201
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Juillet 2012
    Messages : 201
    Points : 73
    Points
    73
    Par défaut simplifier une condition If avec or
    Bonjour

    je cherche à alléger une condition comportant 28 items avec Or :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    If cboChoixSrce.Text = "BRH" Or cboChoixSrce.Text = "Scie murale" Or cboChoixSrce.Text = "Scie circulaire" Or cboChoixSrce.Text = "Perceuse" Or etc...
    Merci

  2. #2
    Membre averti
    Homme Profil pro
    Inscrit en
    Juin 2011
    Messages
    181
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2011
    Messages : 181
    Points : 377
    Points
    377
    Par défaut
    Bonjour à tous,

    Réfléchissons un peu ... Il me semble qu'à la lecture de vos posts, vous avez au total 28 items pour ce Control ComboBox. Il suffirait donc d'écrire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    If cboChoixSrce.Text <> "" Then ...
    Cordialement.

  3. #3
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    12 886
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur, développeur et consultant Excel, Access, Word et VBA

    Informations forums :
    Inscription : Janvier 2010
    Messages : 12 886
    Points : 28 843
    Points
    28 843
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    Un petit exemple
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Dim myList As String
    myList = "BRH;Scie murale;Scie circulaire;Perceuse"
    If InStr(myList, "Scie") Then MsgBox "Yes"
    Donc par exemple avec ton cas
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Dim myList As String
    myList = "BRH;Scie murale;Scie circulaire;Perceuse"
    If InStr(myList, cboChoixSrce.Text) Then MsgBox "Yes"
    Philippe Tulliez
    Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément. (Nicolas Boileau)
    Lorsque vous avez la réponse à votre question, n'oubliez pas de cliquer sur et si celle-ci est pertinente pensez à voter
    Mes tutoriels : Utilisation de l'assistant « Insertion de fonction », Les filtres avancés ou élaborés dans Excel
    Mon dernier billet : Utilisation de la fonction Dir en VBA pour vérifier l'existence d'un fichier

  4. #4
    Membre régulier
    Homme Profil pro
    Inscrit en
    Juillet 2012
    Messages
    201
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Juillet 2012
    Messages : 201
    Points : 73
    Points
    73
    Par défaut
    Merci pour votre aide , vos deux propositions sont totalement différents mais foncionnent toutes les deux.

    J epense que je vais faire comme ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Dim myList As String
    myList = ThisWorkbook.Worksheets("Config!A2:A29")
    If InStr(myList, cboChoixSrce.Text) Then MsgBox "Yes"
    car ma liste est dans un tableau dans une feuille appellée Config

    Encore Merci

    petit soucis je m'y prends mal, comment mettre dans myList les outils classés dans ma feuille "Config" de A2 à A29 ?

    petite précision, le code est dans le module de l'userform

  5. #5
    Membre régulier
    Homme Profil pro
    Inscrit en
    Juillet 2012
    Messages
    201
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Juillet 2012
    Messages : 201
    Points : 73
    Points
    73
    Par défaut
    Super j'ai réussi , j'ai fait comme ça:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    Dim myList As String, str As String
     
     str = UserForm1.cboChoixSrce.Text
     
    myList = ThisWorkbook.Worksheets("Config").Range("A2:A29").Find(str, LookIn:=xlValues, lookat:=xlWhole)
     
    If InStr(myList, cboChoixSrce.Text) Then MsgBox "Yes"

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

Discussions similaires

  1. Réponses: 5
    Dernier message: 06/01/2015, 16h45
  2. simplifier une conditions
    Par JackNUMBER dans le forum Langage
    Réponses: 2
    Dernier message: 07/06/2010, 10h38
  3. Réponses: 3
    Dernier message: 24/10/2005, 13h47
  4. Problème de requête avec une condition IN
    Par sorcer1 dans le forum Langage SQL
    Réponses: 5
    Dernier message: 20/10/2005, 11h56
  5. envoyer submit avec une condition !
    Par delphinote dans le forum Balisage (X)HTML et validation W3C
    Réponses: 4
    Dernier message: 01/07/2005, 15h52

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