Hi,
You only need to select the folder. I tweaked the code little bit.
Use this code.
Code:Dim dic As Object Dim Counter As Long Sub kTest() Dim r As Long Dim c As Long Dim n As Long Dim j As Long Dim Fldr As String Dim Fname As String Dim wbkActive As Workbook Dim wbkSource As Workbook Dim Dest As Range Dim d, k() '// User settings Const SourceFileType As String = "xls*" 'xls,xlsx,xlsb,xlsm Const DestinationSheet As String = "Sheet1" Const DestStartCell As String = "A1" '// End Application.ScreenUpdating = False Counter = 0 With Application.FileDialog(4) .Title = "Select source file folder" .AllowMultiSelect = False If .Show = -1 Then Fldr = .SelectedItems(1) Else GoTo Xit End If End With Set dic = CreateObject("scripting.dictionary") dic.comparemode = 1 Set wbkActive = ThisWorkbook ReDim k(1 To 50000, 1 To 100) Set Dest = wbkActive.Worksheets(DestinationSheet).Range(DestStartCell) Fname = Dir(Fldr & "\*." & SourceFileType) Do While Len(Fname) If wbkActive.Name <> Fname Then Set wbkSource = Workbooks.Open(Fldr & "\" & Fname) With wbkSource.Worksheets(1) If WorksheetFunction.CountA(.Rows(1)) = 0 Then .Rows(1).Delete d = .Range("a1").CurrentRegion UniqueHeaders Application.Index(d, 1, 0) For r = 2 To UBound(d, 1) 'skips header If Len(d(r, 1)) Then n = n + 1 For c = 1 To UBound(d, 2) If Len(Trim$(d(1, c))) Then j = dic.Item(Trim$(d(1, c))) k(n, j) = d(r, c) End If Next End If Next Erase d End With wbkSource.Close 0 Set wbkSource = Nothing End If Fname = Dir() Loop If n Then Dest.Resize(, dic.Count) = dic.keys Dest.Offset(1).Resize(n, dic.Count) = k MsgBox "Done", vbInformation, "ExcelFox.com" End If Xit: Application.ScreenUpdating = True End Sub Private Sub UniqueHeaders(ByRef DataHeader) Dim i As Long Dim j As Long With Application j = .ScreenUpdating .ScreenUpdating = False End With For i = LBound(DataHeader) To UBound(DataHeader) If Len(Trim$(DataHeader(i))) Then If Not dic.exists(Trim$(DataHeader(i))) Then Counter = Counter + 1 dic.Add Trim$(DataHeader(i)), Counter End If End If Next Application.ScreenUpdating = j End Sub




Reply With Quote
Bookmarks