Trying to compile a bunch of worksheets from different .xls files into one spreadsheet

Joined
Jul 14, 2022
Messages
21
Office Version
  1. 2016
Platform
  1. Windows
Forgive my cluelessness, I'm new to power query and the like. I have monthly spreadsheets going back quite a few years, and there's one tab/worksheet from each that I want compiled into my new spreadsheet (let's call the worksheet "slime", which I'm trying to move into my new spreadsheet, "historical slime"). It'd take me all day to manually open, move or copy, copy to the new file I'm making - is there a good way to go about automating this? Only nuances involved: the files are all excel 97-03 worksheets (.xls), I'm doing this in excel 2016, and the worksheet name "slime" is identical in each and every file. Wouldn't be very time consuming for me to go through and manually rename them "MonthYear" once they're in the consolidated spreadsheet though.

Thanks in advance
 

Excel Facts

Is there a shortcut key for strikethrough?
Ctrl+S is used for Save. Ctrl+5 is used for Strikethrough. Why Ctrl+5? When you use hashmarks to count |||| is 4, strike through to mean 5.
Place your Master Workbook in the same Folder as all the .xls files that will be copied.

Paste the following into a routine module :

VBA Code:
Sub Maybe_Like_So()
Dim wb As String
    Application.ScreenUpdating = False
    wb = Dir(ThisWorkbook.Path & "\*")
    
    Do Until wb = ""
    
        If wb <> ThisWorkbook.Name Then
        
            Workbooks.Open ThisWorkbook.Path & "\" & wb
            
                With Workbooks(wb).Sheets("Slime")
                    .UsedRange.Offset(1).Copy ThisWorkbook.Sheets("Historical Slime").Cells(Rows.Count, 1).End(xlUp).Offset(1)
                End With
            
            Application.CutCopyMode = False
            Workbooks(wb).Close False
            
        End If
        
        wb = Dir
    
    Loop
    Application.ScreenUpdating = True
    
End Sub

The above macro should copy only the tabs named "Slime" into the Master Workbook / Sheet "Historical Slime" ... one below the other.

Your Master Workbook can be named anything you want. The sheet to be pasted to should be named "Historical Slime".
 
Upvote 0
Solution
Place your Master Workbook in the same Folder as all the .xls files that will be copied.

Paste the following into a routine module :

VBA Code:
Sub Maybe_Like_So()
Dim wb As String
    Application.ScreenUpdating = False
    wb = Dir(ThisWorkbook.Path & "\*")
   
    Do Until wb = ""
   
        If wb <> ThisWorkbook.Name Then
       
            Workbooks.Open ThisWorkbook.Path & "\" & wb
           
                With Workbooks(wb).Sheets("Slime")
                    .UsedRange.Offset(1).Copy ThisWorkbook.Sheets("Historical Slime").Cells(Rows.Count, 1).End(xlUp).Offset(1)
                End With
           
            Application.CutCopyMode = False
            Workbooks(wb).Close False
           
        End If
       
        wb = Dir
   
    Loop
    Application.ScreenUpdating = True
   
End Sub

The above macro should copy only the tabs named "Slime" into the Master Workbook / Sheet "Historical Slime" ... one below the other.

Your Master Workbook can be named anything you want. The sheet to be pasted to should be named "Historical Slime".
Thank you, seems to be working for me. Gonna have to do a lot of cleaning up but this is a lot better than opening each individual file.
 
Upvote 0
Thank you, seems to be working for me. Gonna have to do a lot of cleaning up but this is a lot better than opening each individual file.
And it has broken excel to an impressive degree. I now have a blank workbook in which I can't select any cells, and I can scroll, but the row/column numbers don't change. Maybe doing 30 months worth at once was a bad idea?
 
Upvote 0
Glad you have an answer !

I was going to suggest what you found on your own. Periodically saving the Master Workbook.
I am curious if implementing a 'pause' between each 'COPY / PASTE ' in conjunction with the
'saving' would also give the macro an opportunity to 'catch up' with the processing.

Cheers
 
Upvote 0
Glad you have an answer !

I was going to suggest what you found on your own. Periodically saving the Master Workbook.
I am curious if implementing a 'pause' between each 'COPY / PASTE ' in conjunction with the
'saving' would also give the macro an opportunity to 'catch up' with the processing.

Cheers
I think half the problem was that each of these monthly workbooks have 10+ sheets and contain links to another 10 workbooks.
 
Upvote 0

Forum statistics

Threads
1,225,389
Messages
6,184,684
Members
453,252
Latest member
ok_lets

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top