RechercheV + Concaténer [Résolu]

yannick.guyon - 2 oct. 2017 à 08:17 - Dernière réponse : gbinforme 14405 Messages postés lundi 18 octobre 2004Date d'inscriptionContributeurStatut 10 décembre 2017 Dernière intervention
- 3 oct. 2017 à 09:35
Bonjour tout le monde,

Je souhaite réaliser une recherche de valeur (exemple : AA-0001) qui correspond à la référence d'un document dans un chemin d'accès (exemple : \\CHEMIN\XX\AA-0001.PDF). Les références se trouvant dans la colonne B et les chemins d'accès dans la colonne A.
Pour faire cela, j'utilises cette formule :
=SIERREUR(RECHERCHEV("*"&B2&"*";$A$2:$A$100;1;FAUX);"")

L'objectif est de faire concorder la référence avec le chemin d'accès pour cette référence dans une colonne C.
Cela fonctionne parfaitement s'il existe un seul document (un seul chemin d'accès) par référence. Mon problème c'est lorsqu'il existe plusieurs documents (plusieurs chemins d'accès) pour une référence. Je souhaite concaténer les chemins d'accès en utilisant un séparateur "###" entre les chemins d'accès.
Je pensais dupliquer mes références réaliser la RECHERCHEV pour toutes les lignes et utiliser une macro de ce type (déjà utiliser pour un autre fichier) pour concaténer :

Sub CONCATENER()
Set ws1 = Sheets("brut")
Set ws2 = Sheets("résultat")
sep = "###"
dl = ws1.Cells(Rows.Count, 1).End(xlUp).Row
ws1.Rows("1:" & dl).Copy ws2.Rows(1)
With ws2
For i = dl - 1 To 2 Step -1
If .Cells(i + 1, 1) = .Cells(i, 1) Then
.Cells(i, 2) = .Cells(i, 2) & sep & .Cells(i + 1, 2)
.Rows(i + 1).Delete shift:=xlUp
End If
Next i
End With
End Sub

Cependant, en réalisant cela, ma RECHERCHEV pour la référence me sort toujours le même chemin d'accès et non tous les chemins d'accès différents pour la référence.

J'espère avoir été clair, n'hésitez pas à revenir vers moi pour des explications supplémentaires.

Merci d'avance à tous ceux qui prendront le temps de jeter un coup d'œil.
Afficher la suite 

5 réponses

Répondre au sujet
gbinforme 14405 Messages postés lundi 18 octobre 2004Date d'inscriptionContributeurStatut 10 décembre 2017 Dernière intervention - 2 oct. 2017 à 09:57
0
Utile
Bonjour,

Pour obtenir ce que tu souhaites (recherchev multiple) je te propose plutôt cette fonction à mettre dans un module
Option Explicit
Function Concat(référence, pl_rch, pl_res)
Dim cel As Range
Const sep = "###"
If pl_rch.Count <> pl_res.Count Then
    Concat = "#PARAM": Exit Function
Else
    Concat = ""
End If
For Each cel In pl_rch
    If cel = référence Then
        If InStr(Concat, pl_res(cel.Row)) = 0 Then
            Concat = Concat & IIf(Concat = "", "", sep) & pl_res(cel.Row)
        End If
    End If
Next cel
End Function

Ensuite dans ta feuille tu l'appelles comme une formule par exemple :
=Concat(C2;B2:B17;A2:A17)
Commenter la réponse de gbinforme
yannick.guyon - 2 oct. 2017 à 15:03
0
Utile
1
Bonjour gbinforme,

Merci pour ton aide.
Je ne parviens pas encore à utiliser ta fonction.
Pour être sur de comprendre dans ton exemple :
référence= la référence que je vais chercher dans les chemins d'accès.
pl_rch= la plage dans laquelle je vais chercher la référence.
pl_res= plage résultat?
gbinforme 14405 Messages postés lundi 18 octobre 2004Date d'inscriptionContributeurStatut 10 décembre 2017 Dernière intervention - 2 oct. 2017 à 21:40
Bonsoir,

Pas étonnant que cela ne fonctionne pas car j'avais mal interprété Les références se trouvant dans la colonne B .

référence= la référence que je vais chercher dans les chemins d'accès.
pl_rch= la plage dans laquelle je vais chercher la référence
celle des chemins d'accès.
Ok c'est bien cela : voici la fonction rectifiée
Option Explicit
Function Concat(référence, pl_rch)
Dim cel As Range
Const sep = "###"
    If référence = "" Then
        Concat = "#PARAM": Exit Function
    Else
        Concat = ""
    End If
    For Each cel In pl_rch
        If InStr(cel.Value, référence) > 0 Then
            If InStr(Concat, cel.Value) = 0 Then
                Concat = Concat & IIf(Concat = "", "", sep) & cel.Value
            End If
        End If
    Next cel
    If Concat = "" Then Concat = "non trouvé"
End Function

tu l'appelles comme une formule par exemple :
=Concat(B2;A2:A200)
Commenter la réponse de yannick.guyon
yannick.guyon - 3 oct. 2017 à 08:22
0
Utile
1
Bonjour,

Un grand merci à toi.
Ta fonction réalise exactement ce que je voulais.

Excellente continuation à toi.
gbinforme 14405 Messages postés lundi 18 octobre 2004Date d'inscriptionContributeurStatut 10 décembre 2017 Dernière intervention - 3 oct. 2017 à 09:35
Bonjour,

Merci du retour et content de t'avoir aidé.
Commenter la réponse de yannick.guyon