Sub Assembler()
Dim chemin$, liste, feuille$, ncol%, lig&, n%, form$, h&
chemin = ThisWorkbook.Path & Application.PathSeparator 'dossier à adapter
liste = Array("Source1.xlsx", "Source2.xlsx", "Source3.xlsx") 'liste des fichiers, à adapter
feuille = "Keywords" 'nom des feuilles à copier, à adapter
ncol = 15 'nombre de colonnes, à adapter
lig = 2 '1ère ligne de restitution, à adapter
Application.ScreenUpdating = False
Application.DisplayAlerts = False
With Feuil1 'CodeName à adapter
.UsedRange.EntireRow.Offset(1).Delete 'RAZ
For n = 0 To UBound(liste)
form = "'" & chemin & "[" & liste(n) & "]" & feuille & "'!"
h = 0
On Error Resume Next
h = ExecuteExcel4Macro("MATCH(""zzz""," & form & "C1)") 'calcul sur colonne 1
On Error GoTo 0
If h > 1 Then
With .Cells(lig, 1).Resize(h - 1, ncol)
.FormulaArray = "=" & form & "R2C1:R" & h & "C" & ncol 'formule de liaison matricielle
.Value = .Value 'supprime la formule
.Replace 0, "", xlWhole 'supprime les zéros
End With
lig = lig + h - 1
End If
Next
With .UsedRange: End With 'actualise les barres de défilement
End With
End Sub