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 :

Validation liste déroulante qui disparait


Sujet :

Macros et VBA Excel

  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Décembre 2010
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2010
    Messages : 2
    Points : 2
    Points
    2
    Par défaut Validation liste déroulante qui disparait
    Bonjour,
    Je fais la validation de données à la saisie dans des cellules avec comme critères une liste d'éléments qui apparaissent dans une liste déroulante à l'intérieur de la cellule.
    Tout va bien en général, sauf qu'à l'occasion et sans raison apparente, la flèche qui permet d'activer la liste déroulante n'apparaît plus sur le côté de la cellule. Je ne peux donc pas sélectionner d'élément dans une liste. Pourtant, la liste semble toujours active pour valider l'information saisie, sauf que je ne peux plus l'utiliser directement.
    Savez-vous qu'est-ce qui peut expliquer la disparition de la flèche permettant d'ouvrir la liste déroulante?
    Merci
    Bernard B.

  2. #2
    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 773
    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 773
    Points : 28 637
    Points
    28 637
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    Dans l'onglet [Options] de la boite de dialogue de l'outil Validation de données tu as deux options à droite du choix Autoriser liste. Une de ces options est Liste déroulante dans la cellule. Cette option est très probablement décochée.
    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

  3. #3
    Membre à l'essai
    Homme Profil pro
    Ingénieur de déploiement réseaux
    Inscrit en
    Décembre 2016
    Messages
    18
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Ingénieur de déploiement réseaux
    Secteur : Bâtiment Travaux Publics

    Informations forums :
    Inscription : Décembre 2016
    Messages : 18
    Points : 17
    Points
    17
    Par défaut
    Salut,

    Juste au cas où ça pourrait servir à quelqu'un d'autre à l'avenir.
    J'ai eu le même soucis : le menu déroulant (la flèche y pour accéder) de ma liste disparaissait alors que la validation de données était toujours présente. Je ne pouvais renseigner dans la case une autre valeur que celles de la liste.

    Voici ce qui se passait dans mon cas :
    Une macro supprime les shapes de ma page.
    Or il s'avère que cette petite flèche pour accéder à la liste est un shape ; il s'appelle "Drop Down 123..."
    La procédure supprimait donc aussi cette fameuse flèche si utile.

    Voici donc mon code modifié pour traité ce problème (avec quelques contrôles pour voir ce qu'il se passe) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
     
    Sub suppr_formes
     
    Dim img as object
    For each img in ActiveSheet.Shapes
      If Left(img.Name, 9) <> "Drop Down" Then
        Debug.print "Supprimer " & img.name
        img.Delete
      Else
        Debug.print "Ne pas supprimer " & img.name
      End if
      Stop
    Next img
    Bonne journée,

    Patrick

  4. #4
    Membre habitué
    Homme Profil pro
    Développeur VBA
    Inscrit en
    Avril 2017
    Messages
    122
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Paris (Île de France)

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

    Informations forums :
    Inscription : Avril 2017
    Messages : 122
    Points : 194
    Points
    194
    Par défaut
    s'il y a des macros, cherchez dans le code ".InCellDropdown = False"
    et voyez si vous pouvez le changer en true.


    ou pour chaque cellule ayant le souci
    cellule.Validation.InCellDropdown = True
    Je ne teste quasi jamais le code que je propose. il s'agit juste d'indication sur comment je m'y prendrais, comment faire, des lignes d'intention.
    Il y a donc souvent des erreurs, le déboggage existe pour cela.

  5. #5
    Membre à l'essai
    Homme Profil pro
    Ingénieur de déploiement réseaux
    Inscrit en
    Décembre 2016
    Messages
    18
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Ingénieur de déploiement réseaux
    Secteur : Bâtiment Travaux Publics

    Informations forums :
    Inscription : Décembre 2016
    Messages : 18
    Points : 17
    Points
    17
    Par défaut
    Salut,

    Je viens d'essayer la propriété .incelldropdown
    En effet, elle permet de remettre la flèche du menu déroulant si celle-ci a disparu.

    Néanmoins, cette propriété ne semble pas simple a utiliser.
    S'il n'y a aucune validation de données sur la cellule tester, la procédure retourne une erreur.
    Mais s'il y en a une et que c'est une liste, on peut enlever ou remettre la flèche.

    Voici une procédure qui remet la flèche du menu déroulant sur une cellule sélectionnée :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    Sub test2()
     
    Dim cell As Range
    For Each cell In Selection.Cells
        MsgBox cell.Validation.InCellDropdown
        cell.Validation.InCellDropdown = True
    Next cell
     
    End Sub
    Bonne journée,

    Patrick

  6. #6
    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 773
    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 773
    Points : 28 637
    Points
    28 637
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    Juste pour votre information, la propriété Validation.InCellDropdown de l'objet Range en VBA correspond exactement à l'option que j'ai indiquée dans ma réponse du 30 juin
    Il suffisait de cocher cette option à l'aide de l'enregistreur de macros pour obtenir le code
    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

  7. #7
    Membre habitué
    Homme Profil pro
    Développeur VBA
    Inscrit en
    Avril 2017
    Messages
    122
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Paris (Île de France)

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

    Informations forums :
    Inscription : Avril 2017
    Messages : 122
    Points : 194
    Points
    194
    Par défaut
    oui je m'en étais rendu compte, par contre je n'avais pas remarqué que c'était un vieux sujet enrichi d'une réponse nouvelle.

    Je suis intervenu parce que le message d'ouverture du sujet indiquait que la raison de disparition de la flèche n'était pas connue, aléatoire. Donc cela ne pouvait pas se faire par "décocher" une case.
    Il restait donc la possibilité du code VBA non maîtrisé, même si le VBA faisait la même chose.

    Ou du raccourci clavier avec erreur de frappe, mais là, c'est moi qui ne maîtrise pas les raccourcis et surtout n'ait pas eu envie de me lancer à explorer cette possibilité car elle me semblait trop improbable.
    Je ne teste quasi jamais le code que je propose. il s'agit juste d'indication sur comment je m'y prendrais, comment faire, des lignes d'intention.
    Il y a donc souvent des erreurs, le déboggage existe pour cela.

Discussions similaires

  1. Validation liste déroulante qui disparait
    Par PeaceBee dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 05/03/2016, 18h01
  2. Réponses: 6
    Dernier message: 04/07/2009, 21h41
  3. [PHP-JS] liste déroulante qui déclecnhe une action.
    Par mikebranque dans le forum Langage
    Réponses: 3
    Dernier message: 05/06/2006, 17h43
  4. Liste déroulante qui contrôle un sous-formulaire
    Par Krowser dans le forum Access
    Réponses: 1
    Dernier message: 02/06/2006, 10h56
  5. Liste déroulante qui ne fonctionne pas -_-'
    Par Shekhmet dans le forum Langage
    Réponses: 5
    Dernier message: 14/03/2006, 12h12

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