+ Reply to Thread
Results 1 to 4 of 4

Merging Data from Multiple Workbooks into 1 Workbook (Inc Subfolders)

Hybrid View

  1. #1
    Registered User
    Join Date
    10-10-2012
    Location
    England
    MS-Off Ver
    Excel 2007
    Posts
    4

    Question Merging Data from Multiple Workbooks into 1 Workbook (Inc Subfolders)

    Hi.

    Wondering if anyone can help?

    I am currently using the following code but I want to make it work on workbooks within subfolders as well:

    Sub MergeAllWorkbooks()
        Dim MyPath As String, FilesInPath As String
        Dim MyFiles() As String
        Dim SourceRcount As Long, FNum As Long
        Dim mybook As Workbook, BaseWks As Worksheet
        Dim sourceRange As Range, destrange As Range
        Dim rnum As Long, CalcMode As Long
    
        ' Change this to the path\folder location of your files.
        MyPath = "C:\Estimate Collation"
        ' Add a slash at the end of the path if needed.
        If Right(MyPath, 1) <> "\" Then
            MyPath = MyPath & "\"
        End If
    
        ' If there are no Excel files in the folder, exit.
        FilesInPath = Dir(MyPath & "*.xl*")
        If FilesInPath = "" Then
            MsgBox "No files found"
            Exit Sub
        End If
    
        ' Fill the myFiles array with the list of Excel files
        ' in the search folder.
        FNum = 0
        Do While FilesInPath <> ""
            FNum = FNum + 1
            ReDim Preserve MyFiles(1 To FNum)
            MyFiles(FNum) = FilesInPath
            FilesInPath = Dir()
        Loop
    
        ' Set various application properties.
        With Application
            CalcMode = .Calculation
            .Calculation = xlCalculationManual
            .DisplayAlerts = False
            .ScreenUpdating = False
            .EnableEvents = False
        End With
    
        ' Add a new workbook with one sheet.
        Set BaseWks = Workbooks.Add(xlWBATWorksheet).Worksheets(1)
        rnum = 1
    
        ' Loop through all files in the myFiles array.
        If FNum > 0 Then
            For FNum = LBound(MyFiles) To UBound(MyFiles)
                Set mybook = Nothing
                On Error Resume Next
                Set mybook = Workbooks.Open(MyPath & MyFiles(FNum))
                On Error GoTo 0
    
                If Not mybook Is Nothing Then
                    On Error Resume Next
    
                    ' Change this range to fit your own needs.
                    With mybook.Worksheets("2013 Data Loader")
                        Set sourceRange = .Range("Data2013")
                    End With
    
                    If Err.Number > 0 Then
                        Err.Clear
                        Set sourceRange = Nothing
                    Else
                        ' If source range uses all columns then
                        ' skip this file.
                        If sourceRange.Columns.Count >= BaseWks.Columns.Count Then
                            Set sourceRange = Nothing
                        End If
                    End If
                    On Error GoTo 0
    
                    If Not sourceRange Is Nothing Then
    
                        SourceRcount = sourceRange.Rows.Count
    
                        If rnum + SourceRcount >= BaseWks.Rows.Count Then
                            MsgBox "There are not enough rows in the target worksheet."
                            BaseWks.Columns.AutoFit
                            mybook.Close savechanges:=False
                            GoTo ExitTheSub
                        Else
    
                            ' Copy the file name in column A.
                            With sourceRange
                                BaseWks.Cells(rnum, "A"). _
                                        Resize(.Rows.Count).Value = MyFiles(FNum)
                            End With
    
                            ' Set the destination range.
                            Set destrange = BaseWks.Range("B" & rnum)
    
                            ' Copy the values from the source range
                            ' to the destination range.
                            With sourceRange
                                Set destrange = destrange. _
                                                Resize(.Rows.Count, .Columns.Count)
                            End With
                            destrange.Value = sourceRange.Value
    
                            rnum = rnum + SourceRcount
                        End If
                    End If
                    mybook.Close savechanges:=False
                End If
    
            Next FNum
            BaseWks.Columns.AutoFit
        End If
    
    ExitTheSub:
        ' Restore the application properties.
        With Application
            .ScreenUpdating = True
            .EnableEvents = True
            .Calculation = CalcMode
            .DisplayAlerts = True
            End With
    End Sub
    So would work in for example

    C:\Estimate Collation\Person1
    C:\Estimate Collation\Person2
    C:\Estimate Collation\Person3
    C:\Estimate Collation\Person4

    As well as just the folder C:\Estimate Collation

    Is this possible?
    Last edited by JBeaucaire; 11-01-2012 at 01:13 PM.

  2. #2
    Forum Expert
    Join Date
    07-15-2012
    Location
    Leghorn, Italy
    MS-Off Ver
    Excel 2010
    Posts
    3,431

    Re: Merging Data from Multiple Workbooks into 1 Workbook (Inc Subfolders)

    http://www.rondebruin.nl/copy3.htm
    If solved remember to mark Thread as solved

  3. #3
    Forum Expert JBeaucaire's Avatar
    Join Date
    03-21-2004
    Location
    Bakersfield, CA
    MS-Off Ver
    2010, 2016, Office 365
    Posts
    33,492

    Re: Merging Data from Multiple Workbooks into 1 Workbook (Inc Subfolders)

    We can take that main macro and turn it into a subroutine that is called by another macro. We feed in the folders to the macro and work our way deeper and deeper until all folders are processed.

    Then we create a main macro to set things in motion... create a blank workbook and feed in the main folder name. That is fed to a "loop" macro that first processes that main folder, then starts detecting folders and restarting the "loop" again in each folder, deeper and deeper until all are processed.

    Option Explicit
    Dim BaseWks As Workbook, rNUM As Long
    
    Sub MainMacro()
    Dim calcmode As Long
        With Application                        ' Set various application properties.
            calcmode = .Calculation
            .Calculation = xlCalculationManual
            .DisplayAlerts = False
            .ScreenUpdating = False
            .EnableEvents = False
        End With
    
    ' Add a new workbook with one sheet, set the first rownumber to use
        Set BaseWks = Workbooks.Add(xlWBATWorksheet).Worksheets(1)
        rNUM = 1
    
    'enter the main path here
        Call LoopController("C:\Estimate Collation")
    
        With Application                ' Restore the application properties.
            .ScreenUpdating = True
            .EnableEvents = True
            .Calculation = calcmode
            .DisplayAlerts = True
        End With
    
    End Sub
    
    
    Private Sub LoopController(sSourceFolder As String)
    'This will loop into itself, first processing the files in the folder
    'then looping into each subfolder deeper and deeper until all folders processed
    Dim Fldr As Object, FL As Object, SubFldr As Object
    
        Call MergeAllWorkbooks(sSourceFolder & Application.PathSeparator)
    
        Set Fldr = CreateObject("scripting.filesystemobject").Getfolder(sSourceFolder)
        For Each SubFldr In Fldr.SubFolders
            LoopController SubFldr.Path
        Next
    
    End Sub
    
    
    Private Sub MergeAllWorkbooks(MyPath As String)
    Dim FilesInPath As String, MyFiles() As String
    Dim SourceRcount As Long, FNum As Long
    Dim mybook As Workbook, BaseWks As Worksheet
    Dim sourceRange As Range, destrange As Range
    
    If Right(MyPath, 1) <> "\" Then MyPath = MyPath & "\"   'Add a slash at the end of the path if needed.
    
    FilesInPath = Dir(MyPath & "*.xl*")
    FNum = 0
        Do While Len(FilesInPath) > 0               ' Fill the myFiles array with the list of Excel files in the search folder.
            FNum = FNum + 1                         ' increment max items for array
            ReDim Preserve MyFiles(1 To FNum)       ' expand array
            MyFiles(FNum) = FilesInPath             ' insert filename into array
            FilesInPath = Dir()                     ' get next filename
        Loop
        
    ' Loop through all files in the myFiles array.
        If FNum > 0 Then
            For FNum = LBound(MyFiles) To UBound(MyFiles)
                Set mybook = Nothing
                On Error Resume Next
                Set mybook = Workbooks.Open(MyPath & MyFiles(FNum))
                On Error GoTo 0
    
                If Not mybook Is Nothing Then
                    On Error Resume Next
    
                    ' Change this range to fit your own needs.
                    With mybook.Worksheets("2013 Data Loader")
                        Set sourceRange = .Range("Data2013")
                    End With
    
                    If Err.Number > 0 Then
                        Err.Clear
                        Set sourceRange = Nothing
                    Else
                        ' If source range uses all columns then
                        ' skip this file.
                        If sourceRange.Columns.Count >= BaseWks.Columns.Count Then
                            Set sourceRange = Nothing
                        End If
                    End If
                    On Error GoTo 0
    
                    If Not sourceRange Is Nothing Then
    
                        SourceRcount = sourceRange.Rows.Count
    
                        If rNUM + SourceRcount >= BaseWks.Rows.Count Then
                            MsgBox "There are not enough rows in the target worksheet."
                            BaseWks.Columns.AutoFit
                            mybook.Close savechanges:=False
                            GoTo ExitTheSub
                        Else
    
                            ' Copy the file name in column A.
                            With sourceRange
                                BaseWks.Cells(rNUM, "A"). _
                                        Resize(.Rows.Count).Value = MyFiles(FNum)
                            End With
    
                            ' Set the destination range.
                            Set destrange = BaseWks.Range("B" & rNUM)
    
                            ' Copy the values from the source range
                            ' to the destination range.
                            With sourceRange
                                Set destrange = destrange. _
                                                Resize(.Rows.Count, .Columns.Count)
                            End With
                            destrange.Value = sourceRange.Value
    
                            rNUM = rNUM + SourceRcount
                        End If
                    End If
                    mybook.Close savechanges:=False
                End If
    
            Next FNum
            BaseWks.Columns.AutoFit
        End If
    
    ExitTheSub:
    End Sub
    Last edited by JBeaucaire; 05-29-2013 at 02:24 AM.
    _________________
    Microsoft MVP 2010 - Excel
    Visit: Jerry Beaucaire's Excel Files & Macros

    If you've been given good help, use the icon below to give reputation feedback, it is appreciated.
    Always put your code between code tags. [CODE] your code here [/CODE]

    ?None of us is as good as all of us? - Ray Kroc
    ?Actually, I *am* a rocket scientist.? - JB (little ones count!)

  4. #4
    Registered User
    Join Date
    10-10-2012
    Location
    England
    MS-Off Ver
    Excel 2007
    Posts
    4

    Re: Merging Data from Multiple Workbooks into 1 Workbook (Inc Subfolders)

    Thanks! Worked a Treat!

+ Reply to Thread

Thread Information

Users Browsing this Thread

There are currently 1 users browsing this thread. (0 members and 1 guests)

Bookmarks

Posting Permissions

  • You may not post new threads
  • You may not post replies
  • You may not post attachments
  • You may not edit your posts

Search Engine Friendly URLs by vBSEO 3.6.0 RC 1