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 :

macro menu déroulant


Sujet :

Macros et VBA Excel

  1. #1
    Membre actif
    Profil pro
    Inscrit en
    Décembre 2010
    Messages
    44
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2010
    Messages : 44
    Par défaut macro menu déroulant
    Bonjour à tous,

    J'ai créé dans ma cellule A7 un menu déroulant avec 2 choix possibles : bleu ou jaune. Si on choisi bleu, je créé en B7 un autre menu déroulant dont la source est située sur la plage C2: D2. Si on choisi jaune, idem que précédemment sauf que la source est située en C3: D3.
    De manière à automatiser la macro (Macro1), j'ai rentré la macro suivante dans mon workbook :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Private Sub Workbook_SheetChange(ByVal Sh As Object, ByVal Target As Range)
    Call Macro1
    End Sub
    Seul bémol, quand je sélectionne jaune ou bleu, un message d'erreur s'affiche ("erreur définie par l'application ou par l'objet"). J'ai la première ligne de code ma macro qui est surlignée (ligne en rouge ci-dessous).
    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
    Sub Macro1()
    
    If ActiveCell.Offset(0, -1).Value = "Jaune" Then
        With Selection.Validation
            .Delete
            .Add Type:=xlValidateList, AlertStyle:=xlValidAlertStop, Operator:= _
            xlBetween, Formula1:="=$C$2:$D$2"
            .IgnoreBlank = True
            .InCellDropdown = True
            .InputTitle = ""
            .ErrorTitle = ""
            .InputMessage = ""
            .ErrorMessage = ""
            .ShowInput = True
            .ShowError = True
        End With
    End If
        
    If ActiveCell.Offset(0, -1).Value = "Bleu" Then
        With Selection.Validation
            .Delete
            .Add Type:=xlValidateList, AlertStyle:=xlValidAlertStop, Operator:= _
            xlBetween, Formula1:="=$C$3:$D$3"
            .IgnoreBlank = True
            .InCellDropdown = True
            .InputTitle = ""
            .ErrorTitle = ""
            .InputMessage = ""
            .ErrorMessage = ""
            .ShowInput = True
            .ShowError = True
        End With
    End If
    End Sub

    Merci d'avance pour votre aide

  2. #2
    Expert confirmé
    Avatar de MarcelG
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2009
    Messages
    3 449
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2009
    Messages : 3 449
    Billets dans le blog
    7
    Par défaut validation
    Bonjour,

    Pourquoi absolument une macro ?

    Si tu nommes liste1 ta zone "C2D2" et liste2 ta zone "C3D3", alors tu peux affecter comme critère de validation "Liste" de ta cellule B7

    Source :
    =SI($A$7="bleu";liste1;liste2)

  3. #3
    pgz
    pgz est déconnecté
    Expert confirmé Avatar de pgz
    Homme Profil pro
    Développeur Office VBA
    Inscrit en
    Août 2005
    Messages
    3 692
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 72
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Office VBA
    Secteur : Conseil

    Informations forums :
    Inscription : Août 2005
    Messages : 3 692
    Par défaut
    Bonjour.

    Je comprends que ce que tu appelles "menu déroulant" est une liste de validation, placée dans la cellule A7.
    Quand tu choisis une valeur, cette cellule A7 est la cellule active.
    Et Activecell.Ofsset(0,-1) est la cellule à gauche de A7. Cette cellule n'existe pas, d'où l'erreur, je pense.

    Cordialement,

    PGZ

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

Discussions similaires

  1. [WD-2010] Macros dans un menu déroulant Word 2010
    Par matzeb dans le forum Word
    Réponses: 3
    Dernier message: 31/01/2012, 10h00
  2. [Toutes versions] Menu déroulant de navigation sans Macro
    Par remy24 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 02/08/2010, 08h20
  3. relation entre menu déroulant et une macro
    Par bem22222 dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 06/01/2010, 15h09
  4. Menu déroulant valeur par défaut
    Par Gourouni dans le forum ASP
    Réponses: 11
    Dernier message: 06/12/2004, 16h31
  5. Menu déroulant suite au passage sur un TMenuItem
    Par James_ dans le forum C++Builder
    Réponses: 2
    Dernier message: 05/05/2004, 14h31

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