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 :

[VBA-E] Userform et case scenario


Sujet :

Macros et VBA Excel

  1. #1
    Mou
    Mou est déconnecté
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    69
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mars 2007
    Messages : 69
    Points : 42
    Points
    42
    Par défaut [VBA-E] Userform et case scenario
    Bonjour,

    J'ai un userform dans lequel j'ai quatre optionbutton. J'aimerai savoir qu'elle est le code pour distinguer chacun des boutons, en utilisant une fonction "Case" au lieu d'utiliser des boucles "IF" imbriques...

    Merci

  2. #2
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Points : 15 543
    Points
    15 543
    Par défaut
    Montre ton code avec tes ifs, on te mettra des cases là où il faut qu'elles soient, si c'est possible...
    A+

  3. #3
    Mou
    Mou est déconnecté
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    69
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mars 2007
    Messages : 69
    Points : 42
    Points
    42
    Par défaut
    Bien sur ! Merci en tout cas de l'aide

    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
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
     
    ComparaisonVisu.Show
     
     
    If ComparaisonVisu.OptionButton3 = True Then
     
        STRSQL3 = "SELECT  Avg(CLO.Vintage) AS MoyenneVintage, avg(CLO.SettlementDate) AS MoyenneSettlementdate, avg(CLO.SizeDeal) AS MoyenneSizeDeal, Count(CLO.Vintage) AS NombreVintage " & _
                  "FROM CLO"
     
        Set Rs3 = Db1.OpenRecordset(STRSQL3, dbOpenSnapshot)
     
        Range("I10").CopyFromRecordset Rs3
     
    End If
     
    If ComparaisonVisu.OptionButton2 = True Then
     
        STRSQL2 = "SELECT  Avg(CLO.Vintage) AS MoyenneVintage, avg(CLO.SettlementDate) AS MoyenneSettlementdate, avg(CLO.SizeDeal) AS MoyenneSizeDeal, Count(CLO.Vintage) AS NombreVintage " & _
                  "FROM CLO"
     
        Set Rs2 = Db1.OpenRecordset(STRSQL2, dbOpenSnapshot)
     
        Range("I10").CopyFromRecordset Rs2
     
    End If
     
    If ComparaisonVisu.OptionButton1 = True Then
     
        STRSQL2 = "SELECT  Avg(CLO.Vintage) AS MoyenneVintage, avg(CLO.SettlementDate) AS MoyenneSettlementdate, avg(CLO.SizeDeal) AS MoyenneSizeDeal, Count(CLO.Vintage) AS NombreVintage " & _
                  "FROM CLO"
     
        Set Rs1 = Db1.OpenRecordset(STRSQL1, dbOpenSnapshot)
     
        Range("I10").CopyFromRecordset Rs1
     
    End If
    Et en fait j'ai 4 gros cas comme ca et avec dedans des mini cas a traiter normalement....

  4. #4
    Modérateur
    Avatar de AlainTech
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Mai 2005
    Messages
    4 235
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 70
    Localisation : Belgique

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : Finance

    Informations forums :
    Inscription : Mai 2005
    Messages : 4 235
    Points : 24 327
    Points
    24 327
    Par défaut
    Euh...

    Je me trompe ou tous tes cas contiennent exactement le même code (à part les noms des variables)?
    N'oubliez pas de cliquer sur quand vous avez obtenu ou trouvé vous-même la réponse à votre question.
    Si vous trouvez seul, pensez à poster votre solution. Elle peut servir à d'autres!
    Pensez aussi à voter pour les réponses qui vous ont aidés.
    ------------
    Je dois beaucoup de mes connaissances à mes erreurs!

  5. #5
    Mou
    Mou est déconnecté
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    69
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mars 2007
    Messages : 69
    Points : 42
    Points
    42
    Par défaut
    Oui oui mais c'est parce que je bosse sur le code et que j'ai fait des copier coller pour expliciter ce que je voulais dire !

  6. #6
    Modérateur
    Avatar de AlainTech
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Mai 2005
    Messages
    4 235
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 70
    Localisation : Belgique

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : Finance

    Informations forums :
    Inscription : Mai 2005
    Messages : 4 235
    Points : 24 327
    Points
    24 327
    Par défaut
    Du coup, pour essayer de simplifier le vrai code, c'est pas évident...

    Pourquoi ne nous donnes-tu pas le code réel?
    N'oubliez pas de cliquer sur quand vous avez obtenu ou trouvé vous-même la réponse à votre question.
    Si vous trouvez seul, pensez à poster votre solution. Elle peut servir à d'autres!
    Pensez aussi à voter pour les réponses qui vous ont aidés.
    ------------
    Je dois beaucoup de mes connaissances à mes erreurs!

  7. #7
    Mou
    Mou est déconnecté
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    69
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mars 2007
    Messages : 69
    Points : 42
    Points
    42
    Par défaut
    Euh ben comme je l'ai dit avant c'est parce que je suis en train de le taper... Je voulais savoir comment on utilisait le "case" avec des optionbuttons...

  8. #8
    Expert éminent sénior

    Homme Profil pro
    Inscrit en
    Août 2005
    Messages
    3 317
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2005
    Messages : 3 317
    Points : 20 144
    Points
    20 144
    Par défaut
    bonjour

    Tu peux placer des OptionButton dans un Frame et tester cette procédure:


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Private Sub CommandButton1_Click()
        Dim Ctrl As Control
     
        For Each Ctrl In Frame1.Controls
            If Ctrl.Object.Value = True Then
                MsgBox Ctrl.Object.Caption
                Exit For
            End If
        Next Ctrl
    End Sub



    michel

  9. #9
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Points : 15 543
    Points
    15 543
    Par défaut
    Oui, ou
    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
    Select case True
          Case Me.OptionButton1.value
                'ton code
          Case Me.OptionButton2.value
                STRSQL2 = "SELECT  Avg(CLO.Vintage) AS MoyenneVintage, avg(CLO.SettlementDate) AS MoyenneSettlementdate, avg(CLO.SizeDeal) AS MoyenneSizeDeal, Count(CLO.Vintage) AS NombreVintage " & _
                  "FROM CLO"
     
                Set Rs1 = Db1.OpenRecordset(STRSQL1, dbOpenSnapshot)
     
                Range("I10").CopyFromRecordset Rs1
          Case Me.OptionButton3.value
                STRSQL3 = "SELECT  Avg(CLO.Vintage) AS MoyenneVintage, avg(CLO.SettlementDate) AS MoyenneSettlementdate, avg(CLO.SizeDeal) AS MoyenneSizeDeal, Count(CLO.Vintage) AS NombreVintage " & _
                  "FROM CLO"
     
                  Set Rs3 = Db1.OpenRecordset(STRSQL3, dbOpenSnapshot)
     
                  Range("I10").CopyFromRecordset Rs3
          Case else
    End select

  10. #10
    Membre expérimenté
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    1 563
    Détails du profil
    Informations personnelles :
    Âge : 61
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 563
    Points : 1 691
    Points
    1 691
    Par défaut
    sinon, pour faire simple et pour le principe
    tu peux faire comme ça
    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
    22
    23
    24
    25
    26
    27
    28
    Public var As Variant
    Public variable As Integer
    Private Sub CommandButton1_Click()
    MsgBox "je t'aime " & var
    End Sub
    Private Sub CommandButton2_Click()
    Select Case variable
    Case 1
    MsgBox "c'est le 1"
    Case 2
    MsgBox "c'est le 2"
    Case 3
    MsgBox "c'est le 3"
    End Select
    End Sub
     
    Private Sub OptionButton1_Click()
    var = "un peu"
    variable = 1
    End Sub
    Private Sub OptionButton2_Click()
    var = "beaucoup"
    variable = 2
    End Sub
    Private Sub OptionButton3_Click()
    var = "A la folie"
    variable = 3
    End Sub
    soit a la façon du bouton 1, soit celle du bouton 2
    ps n'y voit rien de personnel

  11. #11
    Mou
    Mou est déconnecté
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    69
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mars 2007
    Messages : 69
    Points : 42
    Points
    42
    Par défaut
    En tout cas c'est mignon comme programme...

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

Discussions similaires

  1. [XL-2007] VBA UserForm avec cases a cocher
    Par pelerin98 dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 16/06/2013, 19h24
  2. [VBA-E]Userform qui "plante"
    Par Elstak dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 02/05/2006, 11h33
  3. [VBA-E]UserFOrm
    Par malloc_92 dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 12/04/2006, 15h24
  4. [VBA-E]Userform et transfert de variable
    Par Yanos dans le forum Macros et VBA Excel
    Réponses: 17
    Dernier message: 27/03/2006, 09h16
  5. [VBA-E] userform TextBox
    Par mulanzia2003 dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 25/03/2006, 09h18

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