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 :

Petit problème sur VBA


Sujet :

Macros et VBA Excel

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2020
    Messages
    55
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 23
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2020
    Messages : 55
    Points : 39
    Points
    39
    Par défaut Petit problème sur VBA
    Bonjour,

    Je viens de commencer à apprendre à coder (enfin vraiment j'en suis aux prémices) mais j'ai un petit problème que je n'arrive pas du tout à faire :
    j'ai besoin d'un code pour associer un nom à un numéro : je me suis fais l'exemple suivant :
    Colin est associé à 30 nombre différents, Tanguy à 30 autres et Arthur 30 autres encore (tous en colonne B). A partir de ces nombres, j'aimerai que le nom associé au nombre apparaisse (en colonne A). Parce que je me suis amusé à faire des Si dans des Si en formule Xcl (et non pas vba) mais on est bloqué a 64 et c'est vraiment lourd, je suis sur que c'est possible de faire plus simple que ce que j'ai fait

    Ah et enfin, je veux aussi faire sur une 2ème feuille une liste déroulante qui fasse effet de filtre en mode : quand on sélectionne Colin, tous les chiffres apparaissent et ce à quoi ils font référence.

    Merci pour votre temps, aide et connaissance

    PS : pour les nombres prenez des nombres aléatoires ca en soit je m'en fiche .


  2. #2
    Expert confirmé
    Homme Profil pro
    Responsable des études
    Inscrit en
    Juillet 2014
    Messages
    2 661
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Aude (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Responsable des études
    Secteur : Santé

    Informations forums :
    Inscription : Juillet 2014
    Messages : 2 661
    Points : 5 785
    Points
    5 785
    Par défaut
    Bonjour,

    Pour ton premier problème intéresse toi a la fonction rechercheV https://support.office.com/fr-fr/art...rs=fr-FR&ad=FR

    Pour le second, recherche "liste en cascade" un exemple: http://boisgontierjacques.free.fr/pa...es_cascade.htm
    J'aimerais bien aller vivre en Théorie, car en Théorie tout se passe bien.

  3. #3
    Invité
    Invité(e)
    Par défaut
    Bonjour,

    Sans utiliser de VBA, je pense que les fonctions soit RECHERCHEV() ou le duo INDEX() et EQUIV() feraient l'affaire

  4. #4
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2020
    Messages
    55
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 23
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2020
    Messages : 55
    Points : 39
    Points
    39
    Par défaut
    la rechercheV ne me semble pas utile : je n'ai qu'une seule info : les nombres et c'est à partir de ces nombres que je veux attribuer un nom, ils ne sont pas déjà dans le tableau. Enfin je ne vois pas comment faire vu qu'ils ne sont pas dans la feuille.

    merci pour ta réponse

  5. #5
    Expert éminent sénior 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
    Points : 32 866
    Points
    32 866
    Par défaut
    Citation Envoyé par Arthursl Voir le message
    Colin est associé à 30 nombre différents, Tanguy à 30 autres et Arthur 30 autres encore (tous en colonne B). A partir de ces nombres, j'aimerai que le nom associé au nombre apparaisse (en colonne A).
    Il faudrait que tu montres une copie d'écran de ton tableau pour comprendre la structure de cette "association".

    Parce que je me suis amusé à faire des Si dans des Si en formule Xcl (et non pas vba) mais on est bloqué a 64 et c'est vraiment lourd, je suis sur que c'est possible de faire plus simple que ce que j'ai fait
    Pourquoi ne pas utiliser une association des fonctions EQUIV() et INDEX() ?
    En supposant que la valeur cherchée est en D1 :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    =INDEX(A:A;EQUIV(D1;B:B;0))
    Ah et enfin, je veux aussi faire sur une 2ème feuille une liste déroulante qui fasse effet de filtre en mode : quand on sélectionne Colin, tous les chiffres apparaissent et ce à quoi ils font référence.
    Pourquoi ne pas simplement placer un filtre sur ta première feuille ?
    Ca se met en place en 10 secondes et ça crée une liste déroulante avec laquelle tu peux masquer les lignes ne correspondant pas aux critères fixés.

    PS : pour les nombres prenez des nombres aléatoires ca en soit je m'en fiche .
    Le problème avec des nombres aléatoires, c'est que rien ne garantit qu'il n'y aura pas de doublons.
    Or, une recherche comme celle que tu présentes ne peut fonctionner que s'il n'y a pas de doublons.

    Citation Envoyé par halaster08 Voir le message
    Pour ton premier problème intéresse toi a la fonction rechercheV
    Pour que RECHERCHEV() fonctionne, il faudrait qu'il inverse ses deux colonnes. INDEX+EQUIV semble plus approprié.
    Merci de cliquer sur pour chaque message ayant aidé puis sur pour clore cette discussion.

  6. #6
    Expert éminent sénior 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
    Points : 32 866
    Points
    32 866
    Par défaut
    Citation Envoyé par Arthursl Voir le message
    la rechercheV ne me semble pas utile : je n'ai qu'une seule info : les nombres et c'est à partir de ces nombres que je veux attribuer un nom, ils ne sont pas déjà dans le tableau. Enfin je ne vois pas comment faire vu qu'ils ne sont pas dans la feuille.
    Dans ta liste, tu dis qu'il y a deux informations : les noms et les nombres.
    Si ce n'est pas ça, une copie d'écran est indispensable pour comprendre ta structure.
    Merci de cliquer sur pour chaque message ayant aidé puis sur pour clore cette discussion.

  7. #7
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2020
    Messages
    55
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 23
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2020
    Messages : 55
    Points : 39
    Points
    39
    Par défaut
    test.xlsxtest.xlsx

    je vous met mon fichier en pj
    merci

  8. #8
    Expert éminent sénior 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
    Points : 32 866
    Points
    32 866
    Par défaut
    Citation Envoyé par Arthursl Voir le message
    je vous met mon fichier en pj
    Beaucoup de participants à ce forum (y compris moi) n'ouvrent pas les fichiers joints, c'est pourquoi je conseillais une copie d'écran.

    As-tu essayé les fonctions INDEX et EQUIV et le filtre ou attends-tu qu'on fasse tes devoirs à ta place ?
    Merci de cliquer sur pour chaque message ayant aidé puis sur pour clore cette discussion.

  9. #9
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2020
    Messages
    55
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 23
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2020
    Messages : 55
    Points : 39
    Points
    39
    Par défaut
    Nom : Sans titre.png
Affichages : 106
Taille : 81,3 Ko
    Nom : Sans titre2.png
Affichages : 109
Taille : 66,8 Ko
    Nom : Sans titre3.png
Affichages : 105
Taille : 52,0 Ko
    Nom : Sans titre4.png
Affichages : 99
Taille : 51,8 Ko

    Voila ma feuille

    Avez-vous une idée pour optimiser tout ca ?

    Merci

  10. #10
    Expert éminent sénior 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
    Points : 32 866
    Points
    32 866
    Par défaut
    Je ne parviens même pas à comprendre ce que tu souhaites faire.
    Saisir les clients de chaque code unique avec des SI plutôt que de les saisir en cellules ??? Je ne comprends pas l'intérêt...
    Si c'est vraiment ça, il serait beaucoup plus simple de faire un tableau en saisissant les codes dans une colonne et les clients dans l'autre.
    Je ne comprends pas non plus pourquoi il y a une seconde colonne (A) de noms qui reprend la colonne C à l'identique et encore moins la fonction de la colonne B.
    Merci de cliquer sur pour chaque message ayant aidé puis sur pour clore cette discussion.

  11. #11
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2020
    Messages
    55
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 23
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2020
    Messages : 55
    Points : 39
    Points
    39
    Par défaut
    En fait, j'ai fait ça en pensant à l'utilité en entreprise : si par exemple les nombres correspondes à des codes clients / fournisseur et que le nom est le nom du vendeur / approvisionneur, si j'ai une nouvelle commande avec un des 90 codes fournisseur, le nom de l'approvisionneur sera automatiquement attribué. Autrement dit, je veux que à partir de 90 lignes d'exemples, que à chaque fois qu'un nouveau produit arrive avec un des codes fournisseur, son approvisionneur va être attribué automatiquement. Prenons un cas simple : le numéro 1 est attribué à A, 2 à B et 3 à C si je reçois un nouveau produit de la part de 1, alors ma colonne nom va automatiquement se remplir avec A.
    L'utilité de la colonne B est que comme on est bloqué à 64 si imbriqué et que j'ai pas trouvé de meilleures formules pour l'instant la colonne B va permettre de continuer les codes à partir du 65ème code jusqu'a la fin...

    Je sais pas si c'est clair...

  12. #12
    Expert éminent sénior 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
    Points : 32 866
    Points
    32 866
    Par défaut
    Citation Envoyé par Arthursl Voir le message
    En fait, j'ai fait ça en pensant à l'utilité en entreprise : si par exemple les nombres correspondes à des codes clients / fournisseur et que le nom est le nom du vendeur / approvisionneur, si j'ai une nouvelle commande avec un des 90 codes fournisseur, le nom de l'approvisionneur sera automatiquement attribué.
    Dans ce cas, il faut se faire une base de données avec la correspondance entre le code (unique) et le vendeur en charge de ce code.
    Ensuite, dans le fichier de travail, on pourra retrouver cette correspondance en utilisant une simple fonction RECHERCHEV() ou une combinaison de INDEX() et EQUIV(), comme il t'a été plusieurs fois spécifié.

    Autrement dit, je veux que à partir de 90 lignes d'exemples, que à chaque fois qu'un nouveau produit arrive avec un des codes fournisseur, son approvisionneur va être attribué automatiquement.
    Il est possible de positionner une RECHERCHEV() qui recherche dans les lignes saisies précédemment en recherchant dans une zone dont l'une des bornes est en adresse absolue et l'autre en adresse négative.
    Mais c'est faire des acrobaties pas très propres.

    Pour faire du travail propre, il faut séparer la partie base de donnée de la saisie courante.

    En tout cas, utiliser des SI() imbriqués pour faire ça, c'est contreproductif. Même s'il n'y avait pas de limitation, ça voudrait dire qu'il faudrait changer la formule chaque fois qu'un nouveau code apparaitrait ? Ce serait aberrant comme fonctionnement.
    Mieux vaut faire une base de données bien propre dans une feuille séparée.
    Merci de cliquer sur pour chaque message ayant aidé puis sur pour clore cette discussion.

  13. #13
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2020
    Messages
    55
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 23
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2020
    Messages : 55
    Points : 39
    Points
    39
    Par défaut
    Effectivement, je n'avais pas pensé à cette solution (pourtant assez simple )
    Merci beaucoup pour ton aide !! je reviendrai si j'ai un autre problème !!

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

Discussions similaires

  1. Aide pour petit problème sur bouton
    Par jeanfly dans le forum Flash
    Réponses: 3
    Dernier message: 14/05/2007, 16h25
  2. petit problème sur les listes chaînées
    Par poche dans le forum C
    Réponses: 14
    Dernier message: 19/03/2007, 16h53
  3. petit problème sur une drawgrid
    Par florette dans le forum Delphi
    Réponses: 2
    Dernier message: 26/05/2006, 09h41
  4. [débutant]petit problème sur formulaire avec onglets
    Par Christophe93250 dans le forum Access
    Réponses: 2
    Dernier message: 06/01/2006, 10h46
  5. [jointure] Petit problème sur le type de jointure...
    Par SteelBox dans le forum Langage SQL
    Réponses: 13
    Dernier message: 13/02/2004, 18h55

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