RechercheH et V avec « FAUX »
Si l’on voulait trouver le nom de famille en E15 à partir du prénom en E14, tout en signalant les erreurs éventuelles, il fallait utiliser une formule du type : =si(E14=recherche(E14;D3:D11);recherche(E14;D3:E11);"Erreur !")…
Il fallut attendre de nombreuses années encore avant que, pour résoudre ce problème, une seconde syntaxe ne soit introduite à chacune de ces deux nouvelles fonctions : =recherchev(valeur;matrice;n°col;exact) et =rechercheh(valeur;matrice;n°lig;exact).
Si l’argument « exact » est absent ou VRAI, la fonction rechercheH ou V fonctionne selon le même algorithme que la fonction recherche(). Si en revanche ce quatrième argument est FAUX, un algorithme totalement différent est utilisé.
Voici ce qu’il donne pour rechercheV : on compare la valeur aux valeurs de la première colonne en commençant par le haut de la colonne ; et on descend, tant que l’on n’a pas trouvé la valeur cherchée. Si l’on parvient à la fin de la colonne sans l’avoir trouvée, la fonction renvoie #NA ! Sinon, elle s’arrête dès qu’elle trouve la valeur (à sa première occurrence, s’il y en a plusieurs) et renvoie alors le contenu de la colonne n°col de la matrice.
Remarque 1 – La conséquence immédiate de l’utilisation de rechercheV (resp. H) avec FAUX en quatrième argument est que la première colonne (resp. ligne) n’a plus besoin d’avoir des valeurs croissantes !
Remarque 2 – Compte tenu de ce nouvel algorithme, s’il y a plusieurs « Gilles » dans la liste, c’est toujours le premier que l’on obtiendra quand le quatrième argument sera FAUX. Alors que ce sera toujours le dernier avec VRAI ou sans quatrième argument…
1 Commentaire(s):
En testant RECHERCHEV en mode exact ("FAUX" !), je me suis aperçu que la table de recherche ne pouvait pas dépasser 100.000 lignes. A 100.001, RECHERCHEV renvoie une erreur...
Curieux quand même comme limitation quand Excel 2010 propose plus d'1000.000 de lignes. Pourquoi s'arrêter à 100.000 ? question de principe.
Plus que curieux, mais surtout gênant, cette limite n'est pas du tout documentée chez Microsoft.
Alors, si ça peut intéresser certains, voici une petite "Function" qui généralise RECHERCHEV avec "FAUX" :
Function MaRECHERCHEV(varValeur As Variant, _
rngTable As Range, intC As Integer)
Application.Volatile
MaRECHERCHEV = rngTable.Columns(1). _
Find(what:=varValeur, LookIn:=xlValues, _
lookat:=xlWhole).Offset(0, intC - 1).Value
End Function
By cduigou, sur 1:50 PM
Enregistrer un commentaire
<< Accueil