1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39
|
Set f1 = Feuil1 ' Ta feuille de données
Set f2 = Feuil5 ' Ta feuille de résultats
nbcol = 7 ' Nombre de colonnes à analyser
Dim tabl ' Tableau temporaire qui concatènera les valeurs
nbref = 1 ' Nb de références sans doublon
tabl = Array("", "", "", "", "", "", "", "") ' Initialisation du tableau
' Tri par la référence
f1.Cells.Sort Key1:=Range("A1"), Order1:=xlAscending, _
Header:=xlGuess, OrderCustom:=1, MatchCase:=False
' Boucle pour parcourir les lignes en comparant la référence entre deux lignes consécutives
For i = 2 To f1.UsedRange.Rows.Count
tabl(1) = f1.Cells(i, 1) ' référence
' Pour chaque colonne, vérifie si la valeur est déjà stockée
For j = 2 To nbcol
If Trim(f1.Cells(i, j)) <> "" Then
If Instr(1, tabl(j), "/ " & f1.Cells(i, j) & " /", vbTextCompare) > 0 Then
' rien car la valeur y est déjà
Else ' Concatène la valeur
tabl(j) = tabl(j) & "/ " & f1.Cells(i, j) & " /"
End If
End If
Next j
' Comparaison de la référence avec la ligne suivante
If Not f1.Cells(i,1) = f1.Cells(i + 1,1) Then
f2.Cells(nbref + 1, 1) = tabl(1)
For j = 2 to nbcol
temp = Replace(tabl(j), "//", "/", vbTextCompare)
If Len(temp) > 4 And Left(temp, 1) = "/" And Right(temp, 1) = "/" Then
f2.Cells(nbref + 1, j) = Mid(temp, 3, Len(temp) - 4)
Else: f2.Cells(nbref + 1, j) = temp
End If
Next j
nbref = nbref + 1
tabl = Array("", "", "", "", "", "", "", "") ' Ré-initialisation du tableau
End If
Next i |
Partager