Boucle sur une recherche à 2 critères
Résolu
grutz
Messages postés
22
Date d'inscription
Statut
Membre
Dernière intervention
-
Utilisateur anonyme -
Utilisateur anonyme -
A voir également:
- Boucle sur une recherche à 2 critères
- Supercopier 2 - Télécharger - Gestion de fichiers
- Recherche automatique des chaînes ne fonctionne pas - Guide
- Comment faire une recherche à partir d'une photo - Guide
- Je recherche une chanson - Guide
- 2 ecran pc - Guide
11 réponses
Essaye ça
Avec

Function RechercheGrutz(Plage As Range, Critere1 As String, Critere2 As String) As Date Dim tableau As Variant tableau = Plage.Value Dim b, c, d As Integer b = LBound(tableau, 2) 'dimension de la première colonne E dans le tableau c = b + 1 'dimension de la deuxième colonne d = UBound(tableau, 2) 'dimension de la troisième colonne For i = LBound(tableau, 1) To UBound(tableau, 1) 'i du début à la fin du tableau If tableau(i, b) = Critere1 Then 'si dans le tableau en colonne 1 = critère 1 'si on trouve le critère 1 dans la colonne 1, on regarde la valeur de la même ligne en colone 2 If tableau(i, c) = Critere2 Then 'si dans le tableau en colonne 2 = critère 2 'on retourne la valeur de la troisième colonne RechercheGrutz = tableau(i, d) Exit Function End If End If Next End Function
Avec
=RechercheGrutz($D$2:$F$7;A2;B2)dans C2 et
=RechercheGrutz($D$2:$F$7;A3;B3)dans C3

grutz
Messages postés
22
Date d'inscription
Statut
Membre
Dernière intervention
Merci beaucoup ça fonctionne très bien :)
Bonjour
T’aider oui, à condition de ne pas paraître agaçant et impatient en postant ta question toutes les 3 minutes
https://forums.commentcamarche.net/forum/affich-37109514-boucle-sur-une-recherche-a-2-criteres
T’aider oui, à condition de ne pas paraître agaçant et impatient en postant ta question toutes les 3 minutes
https://forums.commentcamarche.net/forum/affich-37109514-boucle-sur-une-recherche-a-2-criteres
Oui je viens de voir que ça l'avait mis 3 fois alors que les deux premières il y a eu une erreur ... je viens de m'en apercevoir et j'ai pas trouvé ou supprimer les demandes
yg_be
Messages postés
23541
Date d'inscription
Statut
Contributeur
Dernière intervention
Ambassadeur
1 583
bonjour,
cela me fait plutôt penser à une boucle imbriquée dans une autre.
bien que tu ne mentionnes qu'une seule fois "valeur suivante"
cela me fait plutôt penser à une boucle imbriquée dans une autre.
bien que tu ne mentionnes qu'une seule fois "valeur suivante"
montre déjà ton code avec une boucle.
tiens compte de ceci: https://codes-sources.commentcamarche.net/faq/11288-les-balises-de-code
tiens compte de ceci: https://codes-sources.commentcamarche.net/faq/11288-les-balises-de-code
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
En utilisant un tableau (voir un tuto ici si tu ne connais pas https://silkyroad.developpez.com/vba/tableaux/ )
Soit la feuille suivante

Dans un module la fonction suivante
Et dans la cellule E2 la formule
Soit la feuille suivante

Dans un module la fonction suivante
Function RechercheGrutz(Critere1 As String, Critere2 As String) As Boolean Dim tableau As Variant tableau = Range("B1:C21").Value Dim b, c As Integer b = LBound(tableau, 2) 'dimension de la colonne B dans le tableau c = UBound(tableau, 2) 'dimension de la colonne C For i = LBound(tableau, 1) To UBound(tableau, 1) If tableau(i, b) = Critere1 Then 'si on trouve le critère 1 dans la colonne b, on regarde la valeur de la même ligne en c If tableau(i, c) = Critere2 Then RechercheGrutz = True Exit Function End If End If Next End Function
Et dans la cellule E2 la formule
=RechercheGrutz(A1;A2)
Bonjour,
merci beaucoup pour cette réponse, J'ai compris la macro+ formule, elle dit vrai en E2 si elle trouve l'association des deux (A1 et A2)
C'est une première piste pour moi, mais encore assez loin de ce que je souhaitais faire.
je joins un imp ecran pour que cela soit plus complet :

Encore merci :)
merci beaucoup pour cette réponse, J'ai compris la macro+ formule, elle dit vrai en E2 si elle trouve l'association des deux (A1 et A2)
C'est une première piste pour moi, mais encore assez loin de ce que je souhaitais faire.
je joins un imp ecran pour que cela soit plus complet :

Encore merci :)
yg_be
Messages postés
23541
Date d'inscription
Statut
Contributeur
Dernière intervention
Ambassadeur
1 583
il suffit alors de programmer deux boucles imbriquées,
une qui parcourt les colonnes A-B, l'autre qui parcourt les colonnes E-F.
je pense, par ailleurs, que c'est facilement réalisable sans programmation, en ajoutant deux colonnes, une qui combine A et B, l'autre qui combine E et F, et en utilisant les fonctions classiques de Excel.
une qui parcourt les colonnes A-B, l'autre qui parcourt les colonnes E-F.
je pense, par ailleurs, que c'est facilement réalisable sans programmation, en ajoutant deux colonnes, une qui combine A et B, l'autre qui combine E et F, et en utilisant les fonctions classiques de Excel.
Dans la macro que je t’ai proposé, au lieu de mettre 2 colonnes dans le tableau, tu en mets 3 et à la place de renvoyer True, tu prends la valeur de la 3ème dimension de la ligne
Merci,
C'est ce que j'avais essayé de faire :
Mais cela ne renvoie pas la colonne G...
C'est ce que j'avais essayé de faire :
Function RechercheGrutz(Critere1 As String, Critere2 As String, Critere3 As String) As Boolean Dim tableau As Variant tableau = Range("E2:G21").Value Dim b, c, d As Integer b = LBound(tableau, 2) 'dimension de la colonne E dans le tableau (1) c = UBound(tableau, 2) - 1 'dimension de la colonne F (2) d = UBound(tableau, 2) 'dimension de la colonne G (3) For i = LBound(tableau, 1) To UBound(tableau, 1) 'i = de 1 à 20 If tableau(i, b) = Critere1 Then 'si dans le tableau de 1 à 20 en colonne 1 = critère 1 'si on trouve le critère 1 dans la colonne e, on regarde la valeur de la même ligne en f If tableau(i, c) = Critere2 Then 'si dans le tableau de 1 à 20 en colonne 2 = critère 2 'si on trouve le critère 2 dans la colonne f, on regarde la valeur de la même ligne en g If tableau(i, d) = Critere3 Then 'si dans le tableau de 1 à 20 en colonne 3 = critère 3 RechercheGrutz = Critere3 Exit Function End If End If Next End Function
Mais cela ne renvoie pas la colonne G...