Boucle sur une recherche à 2 critères

Résolu
grutz Messages postés 22 Date d'inscription   Statut Membre Dernière intervention   -  
 Utilisateur anonyme -
Bonjour à tous,

je voulais avoir si vous avez déjà réussi à faire une boucle sur une recherche à 2 critères ?

J'ai beau avoir posé mon problème par écrit mais je n'arrive pas à le mettre en forme ...

Par exemple :

Valeur Cherché en A1 (par exemple : AM1)
Si cette valeur est trouvé dans la plage B:B alors;
Cherche la valeur se trouvant sur la même ligne en plage C:C. Si la valeur correspond à "02/2021" alors;
"VRAI" sinon;
Valeur suivante dans la plage B:B jusqu'à plus de valeur correspondant à "AM1" en plage B:B.

est il possible de m'aider ?

bonne journée,

Cordialement
A voir également:

11 réponses

Utilisateur anonyme
 
Essaye ça
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

1
grutz Messages postés 22 Date d'inscription   Statut Membre Dernière intervention  
 
Merci beaucoup ça fonctionne très bien :)
0
Utilisateur anonyme
 
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
0
grutz Messages postés 22 Date d'inscription   Statut Membre Dernière intervention  
 
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
0
yg_be Messages postés 23541 Date d'inscription   Statut Contributeur Dernière intervention   1 583
 
tu n'as pas trouvé non plus comment y ajouter un commentaire pour expliquer la situation?
0
grutz Messages postés 22 Date d'inscription   Statut Membre Dernière intervention   > yg_be Messages postés 23541 Date d'inscription   Statut Contributeur Dernière intervention  
 
Je ne suis pas un habitué du forum... je cherchais en vain un bouton "supprimer"
0
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"
0
yg_be Messages postés 23541 Date d'inscription   Statut Contributeur Dernière intervention   1 583
 
il serait préférable de t'expliquer en français.
0
grutz Messages postés 22 Date d'inscription   Statut Membre Dernière intervention  
 
Bonjour,
Il est possible qu'il y est plus de 6 fois la même valeur "AM1" en plage B:B sur le fichier mais toutes à des dates différentes "02 2021"; "06 2021" ....
donc valeurs suivante jusqu'a ce qu'il est epuisé toute les valeurs "AM1"
merci,
0
yg_be Messages postés 23541 Date d'inscription   Statut Contributeur Dernière intervention   1 583 > grutz Messages postés 22 Date d'inscription   Statut Membre Dernière intervention  
 
montre déjà ton code avec une boucle.
tiens compte de ceci: https://codes-sources.commentcamarche.net/faq/11288-les-balises-de-code
0

Vous n’avez pas trouvé la réponse que vous recherchez ?

Posez votre question
Utilisateur anonyme
 
Un modérateur viendra s’en charger
0
Utilisateur anonyme
 
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
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)

0
grutz Messages postés 22 Date d'inscription   Statut Membre Dernière intervention  
 
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 :)
0
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.
0
Utilisateur anonyme
 
Tu veux que ça renvoies la valeur de la colonne G, c'est ça?
0
grutz Messages postés 22 Date d'inscription   Statut Membre Dernière intervention  
 
Oui exactement :) . Comme un recherche V ou un equiv index sauf que ces deux formules renvoient à la première valeur trouvée alors que dans mon tableau les valeurs en "E" peuvent revenir plusieurs fois.
0
Utilisateur anonyme
 
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
0
grutz Messages postés 22 Date d'inscription   Statut Membre Dernière intervention  
 
Merci,
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...
0
Utilisateur anonyme
 
Je ne comprends pas ce que vient faire le 3eme critère en paramètre.

Pour moi c'est la valeur que tu veux découvrir, si tu l'imposes en entrée, c'est que tu la connais déjà donc ta recherche ne sert à rien.

0
Utilisateur anonyme
 
De rien
0