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 :

Liste de possibilités en fonction de plusieurs cellules


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre du Club
    Femme Profil pro
    Chef de projet en SSII
    Inscrit en
    Février 2019
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Chef de projet en SSII
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2019
    Messages : 9
    Par défaut Liste de possibilités en fonction de plusieurs cellules
    Bonjour,

    Je suis sur une problématique que je n'arrive pas à résoudre.
    Je ne crois pas qu'il y ait de fonction qui fasse ce que je souhaite.
    Je me suis orienté par conséquent sur une macro.
    Mais j'atteins mes limites .....


    Match 1 : Equipe 1.1 / 1.Nul / Equipe 1.2
    Match 2 : Equipe 2.1 / 2.Nul / Equipe 2.2
    Match 3 : Equipe 3.1 / 3.Nul / Equipe 3.2


    Avec l'exemple des 3 matchs, je souhaite affiché dans une autre feuille Excel la liste complète des possibilités. Dans l'exemple de 3 matchs ci-dessus, ca fait 27 possibilités
    Ex :
    - Equipe 1.1 / Equipe 2.1 / Equipe 3.1
    - Equipe 1.1 / Equipe 2.1 / 3.Nul
    - Equipe 1.1 / Equipe 2.1 / Equipe 3.2
    - Equipe 1.1 / 2.Nul / Equipe 3.1
    - Equipe 1.1 / 2.Nul / 3.Nul
    - Equipe 1.1 / 2.Nul / Equipe 3.2
    - 1.Nul / 2.Nul / 3.Nul
    - 1.Nul / Equipe 2.1 / 3.Nul
    - 1.Nul / Equipe 2.2 / 3.Nul
    - 1.Nul / Equipe 2.1 / Equipe 3.1
    - 1.Nul / Equipe 2.1 / Equipe 3.2
    - ......


    Et l'objectif final, serait de pouvoir choisir via cette macro, de ne pas jouer forcément les 3 possibilités d'un match, ce qui ferait dans l'exemple ci-dessous 4 possibilités
    Ex :
    - Match 1 : Equipe 1.1 / 1.Nul ......... (Equipe 3.1 ne doit pas être présente dans la liste)
    - Match 2 : Equipe 2.1 / 1.Nul ......... (Equipe 3.1 ne doit pas être présente dans la liste)
    - Match 3 : 3.Nul (Equipe 1.1 et Equipe 2.1 non présente dans la liste)

    Et dans l'exemple, je n'ai cité que 3 matchs, mais l'optique est que l'algo fonctionne également avec un nombre aléatoires de matchs (ex : 9 ou 17 matchs)

    Merci d'avance pour votre aide,

  2. #2
    Expert éminent Avatar de Menhir
    Homme Profil pro
    Ingénieur
    Inscrit en
    Juin 2007
    Messages
    16 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2007
    Messages : 16 037
    Par défaut
    Citation Envoyé par gpdeveloppeur Voir le message
    Et dans l'exemple, je n'ai cité que 3 matchs, mais l'optique est que l'algo fonctionne également avec un nombre aléatoires de matchs (ex : 9 ou 17 matchs)
    D'abord, il ne faut pas confondre "aléatoire" et "variable" qui impliquent des procédures très différentes.

    Ensuite, 3 possibilités sur 17 matchs, ça fait près de 130 millions de possibilités, ce qui dépasse largement le nombre de lignes possibles d'Excel et encore plus le nombre de lignes qu'un humain peut visuellement traiter.
    Je pense donc que l'établissement de cette liste n'aurait pas de valeur puisqu'elle devrait ensuite être traitée par un procédé automatique pour être utilisable. Donc, autant shunter l'établissement de la liste et passer au traitement automatique.
    Mais pour ça, il faudrait avoir plus d'infos.

  3. #3
    Membre du Club
    Femme Profil pro
    Chef de projet en SSII
    Inscrit en
    Février 2019
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Chef de projet en SSII
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2019
    Messages : 9
    Par défaut
    Effectivement, 3^17 fait beaucoup de possibilités.

    Pour commencer, imaginons le faire avec juste 3 matchs, à 3 possibilités, on a 27 possibilités.
    Mais imaginons que pour le match 1, je ne souhaite qu'un choix, pour le match 2 je ne souhaite que 2 choix, et pour le match 3 avec 3 choix, cela fait 6 possibilités.

    Comment je peux faire ?

    N°Match Choix 1 Choix 2 Choix 3
    Match 1 Equipe Chien Nul Equipe Chat
    Match 2 Equipe Araignée Nul
    Match 3 Equipe Pigeon

    Ce que j'aimerais réussir à faire est :

    Sol.1 Sol.2 Sol.3 Sol.4 Sol.5 Sol.6
    Equipe Chien Equipe Chien Nul Nul Equipe Chat Equipe Chat
    Equipe Araignée Nul Equipe Araignée Nul Equipe Araignée Nul
    Equipe Pigeon Equipe Pigeon Equipe Pigeon Equipe Pigeon Equipe Pigeon Equipe Pigeon

    Merci d'avance pour votre aide ou conseils.

  4. #4
    Membre du Club
    Femme Profil pro
    Chef de projet en SSII
    Inscrit en
    Février 2019
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Chef de projet en SSII
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2019
    Messages : 9
    Par défaut
    Aux vues du nombre de réponses, j'ai l'impression que le sujet n'est effectivement pas très simple, et que personne n'a jamais dû chercher à faire un système de la sorte.....
    En attendant vos aides, je continue mon investigation en mode macro (avec laquelle je lutte).

    Merci beaucoup d'avance à qui pourrait m'aiguiller.

  5. #5
    Expert éminent Avatar de Menhir
    Homme Profil pro
    Ingénieur
    Inscrit en
    Juin 2007
    Messages
    16 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2007
    Messages : 16 037
    Par défaut
    Citation Envoyé par gpdeveloppeur Voir le message
    Aux vues du nombre de réponses, j'ai l'impression que le sujet n'est effectivement pas très simple, et que personne n'a jamais dû chercher à faire un système de la sorte.....
    C'est surtout parce que ce type d'application produisant des milliers de ligne est inutile pour les raisons que j'ai expliqué au post#2.
    Donc, passer du temps pour rien, ça ne motive pas grand monde...

  6. #6
    Expert éminent Avatar de Menhir
    Homme Profil pro
    Ingénieur
    Inscrit en
    Juin 2007
    Messages
    16 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2007
    Messages : 16 037
    Par défaut
    Une solution sans macro.

    En supposant que le tableau des données sources que tu présentes est en A1:D4.

    En E2, tu mets la formule :
    Tu copies E2 en E2:E4.

    Tu mets 1,2,3 en entête des colonnes G à H et K à M comme sur l'image.
    Tu mets 1 dans les cellules G2:H2.

    En G3, tu mets la formule :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    =SI(LIGNE()>PRODUIT($E$2:$E$4)+1;"-";SI(H3=1;MOD(G2;DECALER($E$1;G$1;0))+1;G2))
    Tu copies G3 en H3.

    En I3, tu mets la formule :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    =SI(LIGNE()>PRODUIT($E$2:$E$4)+1;"-";MOD(I2;DECALER($E$1;I$1;0))+1)
    Tu copies G3:I3 vers le bas autant que nécessaire.

    En K2, tu mets la formule :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    =SIERREUR(INDEX(DECALER($B$1:$D$1;K$1;0);G2);"-")
    Tu copies K2 en K2:M2.
    Tu copies K2:M2 vers le bas autant que nécessaire.

    Nom : Combi.jpg
Affichages : 179
Taille : 85,0 Ko

Discussions similaires

  1. [XL-2013] Automatiser une fonction sur plusieurs cellules différentes
    Par enzo65 dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 27/03/2019, 12h57
  2. [XL-2010] Etablir une liste de doublons en fonction de plusieurs critères
    Par filsdepub dans le forum Excel
    Réponses: 1
    Dernier message: 07/09/2015, 15h32
  3. [Toutes versions] Fonction IF plusieurs cellules
    Par JiBé91 dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 07/11/2012, 13h15
  4. [XL-2003] Nommer feuille en fonction de plusieurs cellules
    Par Raphael13 dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 03/05/2009, 21h38
  5. Fonction Excel Ecrivant Dans Plusieurs Cellules
    Par Denis14T dans le forum Macros et VBA Excel
    Réponses: 7
    Dernier message: 18/04/2007, 21h57

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