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 conditionnelle sur liste variable en tableau nommé


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Responsable de projet fonctionnel
    Inscrit en
    Mai 2022
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Responsable de projet fonctionnel
    Secteur : Bâtiment

    Informations forums :
    Inscription : Mai 2022
    Messages : 6
    Par défaut Validation conditionnelle sur liste variable en tableau nommé
    Bonjour

    Je cherche à coder en VBA une formule à appliquer à toutes les lignes d'une colonne d'un tableau, de type validation de données sur liste, mais la liste varie à chaque ligne du tableau en fonction de la donnée d'une autre cellule de la ligne.


    Feuille 1 : Tableau nommé à 3 colonnes ; appelons le TABLEAU
    Colonne A : contient des noms [NOM] d'objets
    Colonne B : contient une caractéristique liée à [NOM] ; nous l'appellerons [PRECISION] ; il n'y a pas unicité des valeurs.

    Dans le Feuille 2 :
    Pour chaque valeur "PRECISION(i)" possible de ma colonne TABLEAU[PRECISION], je dispose ici d'une LISTE sous forme de tableau nommé "PRECISION(i)" ; ces tableaux ont été pré-renseignés, et sont des tableaux mono-colonnes, qui comportent une série de valeurs possibles.

    Retour sur la Feuille 1
    Colonne C : Je dois y saisir manuellement une valeur [CHOIX], mais cette valeur doit être limitée à la liste du tableau nommé "PRECISION(i)".

    Le code VBA à écrire consiste à automatiser la mise en place de cette condition de validation de données.

    La formule suivante ne fonctionne pas mais résume globalement (à mon sens) ce que je cherche à coder dans les cellules de la colonne [CHOIX] de TABLEAU :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
       With Selection.Validation
            .Delete
            .Add Type:=xlValidateList, AlertStyle:=xlValidAlertStop, Operator:=xlBetween, Formula1:="=INDIRECT(""[@[PRECISION]]"")"
            .IgnoreBlank = True
            .InCellDropdown = True
            .InputTitle = ""
            .ErrorTitle = ""
            .InputMessage = ""
            .ErrorMessage = ""
            .ShowInput = True
            .ShowError = True
        End With
    Merci d'avance de votre aide

  2. #2
    Expert confirmé
    Avatar de Qwazerty
    Homme Profil pro
    La très haute tension :D
    Inscrit en
    Avril 2002
    Messages
    4 128
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France

    Informations professionnelles :
    Activité : La très haute tension :D
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2002
    Messages : 4 128
    Par défaut
    Salut

    Par tableau nommé, tu veux dire tableau structuré? Si c'est le cas, il suffit de créer ta validation et elle va s'entendre toute seule aux nouvelles lignes.

    La création du tableau structuré se fait via le menu Insertion, Tableau.

    ++
    Qwaz

    MagicQwaz := Harry Potter la baguette en moins
    Le monde dans lequel on vit
    Ma page perso DVP
    Dernier et Seul Tutoriel : VBA & Internet Explorer
    Dernière contribution : Lien Tableau Structuré et UserForm
    L'utilisation de l’éditeur de message

  3. #3
    Nouveau membre du Club
    Homme Profil pro
    Responsable de projet fonctionnel
    Inscrit en
    Mai 2022
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Responsable de projet fonctionnel
    Secteur : Bâtiment

    Informations forums :
    Inscription : Mai 2022
    Messages : 6
    Par défaut
    Bonjour Qwazerty

    Oui, il s'agit d'un tableau structuré.

    MAIS : comme la liste à laquelle la validation fait appel n'est pas une liste à nom fixe, mais une liste à noms variables, la validation ne s'étend pas toute seule, ou alors la syntaxe n'est pas la bonne.
    En enregistrant une macro pour comprendre le codage VBA, il n'est pas fait appel à une référence de type INDIRECT([@[PRECISION]]) mais à une adresse de cellule de type INDIRECT(B2)

    J'ai ailleurs dans mon tableau des validation sur une liste fixe codées façon INDIRECT(LISTE_FIXE) qui fonctionnent effectivement très bien et se dupliquent d'elles-mêmes.
    Pas dans le cas que je cherche à résoudre.

    Si j'ai été clair...


    Citation Envoyé par Qwazerty Voir le message
    Salut

    Par tableau nommé, tu veux dire tableau structuré? Si c'est le cas, il suffit de créer ta validation et elle va s'entendre toute seule aux nouvelles lignes.

    La création du tableau structuré se fait via le menu Insertion, Tableau.

    ++
    Qwaz

  4. #4
    Expert éminent

    Profil pro
    Conseil, Formation, Développement - Indépendant
    Inscrit en
    Février 2010
    Messages
    8 564
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Conseil, Formation, Développement - Indépendant

    Informations forums :
    Inscription : Février 2010
    Messages : 8 564
    Par défaut
    Bonjour

    Je confirme que l'on peut faire cela sans VBA

    Il suffit d'avoir une formule nommée relative à la position de la cellule [NOM] qui va associer la bonne liste déroulante

    On peut soit faire une multitude de listes et utiliser INDIRECT mais c'est assez limitatif pour le choix des noms, sauf à passer par une table de correspondance, et devient vite usine à gaz.

    Il est généralement plus efficace de faire une liste unique, tableau nommé Types par exemple, avec une colonne pour les noms d’objets et une autre pour leurs caractéristiques : on a autant de lignes pour un objet qu'il a de caractéristiques à lister.
    La liste est classée par Objet et Caractéristique et les sous-listes sont affichées via la formule nommée à base de DECALER, par exemple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    =DECALER(Types[[#En-têtes];[Type]];EQUIV(Feuil1!$A2;Types[Nom];0);;NB.SI(Types[Nom];Feuil1!$A2))
    créée à partir de B2 (ou autre colonne de la ligne 2) devant se référer au nom d'objet en A2

  5. #5
    Nouveau membre du Club
    Homme Profil pro
    Responsable de projet fonctionnel
    Inscrit en
    Mai 2022
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Responsable de projet fonctionnel
    Secteur : Bâtiment

    Informations forums :
    Inscription : Mai 2022
    Messages : 6
    Par défaut
    Merci 78chris pour ce retour... qui ne me résoud malheureusement pas mon souci.

    J'ai besoin de coder en VBA pour appliquer des macros à des tableaux dont le contenu est très variable selon les jours ; je cherche à automatiser le traitement de ces données ; d'où le VBA.
    Car sans VBA, j'ai la solution pour appeler les listes une par une par la fonction de validation des données, que je copie et colle ensuite sur tout la colonne de mon tableau structuré.
    Et c'est dans le codage en VBA que je ne trouve pas la solution pour faire varier la liste à laquelle la validation des données fait appel

    Bonne journée

  6. #6
    Expert éminent

    Profil pro
    Conseil, Formation, Développement - Indépendant
    Inscrit en
    Février 2010
    Messages
    8 564
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Conseil, Formation, Développement - Indépendant

    Informations forums :
    Inscription : Février 2010
    Messages : 8 564
    Par défaut
    RE
    Citation Envoyé par ChrisLyon1 Voir le message
    Merci 78chris pour ce retour... qui ne me résoud malheureusement pas mon souci.
    Soit j'ai mal compris ta question et de toute évidence, il n'y a pas que moi et donc il faut reformuler avec un exemple concret
    soit tu as mal compris la réponse...

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

Discussions similaires

  1. [XL-2010] Macro Boucle depuis une BASE sur liste variable
    Par bobbydu77 dans le forum Excel
    Réponses: 1
    Dernier message: 07/03/2020, 17h42
  2. Point d'arrêt conditionnel sur une variable
    Par bvsud dans le forum Delphi
    Réponses: 2
    Dernier message: 28/10/2016, 22h13
  3. Min Conditionnel sur plusieurs variables
    Par Korleone dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 23/11/2013, 18h46
  4. [SimpleXML] Conditionnel sur des variables XML
    Par Hightuxdotnet dans le forum Bibliothèques et frameworks
    Réponses: 2
    Dernier message: 20/08/2008, 10h55
  5. [VBA-E]Structure conditionnelle sur plusieurs variables
    Par rodrigue62 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 30/07/2007, 14h30

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