I got a call from a friend who wanted to combine multiple Excel files into one Excel workbook. He had a lot of files in a folder and he wanted to get all the worksheets from all the workbooks into one single workbook.
While this can be done manually, it would be time-consuming and error-prone.
However, a simple VBA code can do this in a few seconds.
Combine Multiple Excel Files into One File
Here is the code that can combine multiple Excel workbooks in a specified folder into a single Excel workbook:
Sub ConslidateWorkbooks() 'Created by Sumit Bansal from https://trumpexcel.com Dim FolderPath As String Dim Filename As String Dim Sheet As Worksheet Application.ScreenUpdating = False FolderPath = Environ("userprofile") & "DesktopTest" Filename = Dir(FolderPath & "*.xls*") Do While Filename <> "" Workbooks.Open Filename:=FolderPath & Filename, ReadOnly:=True For Each Sheet In ActiveWorkbook.Sheets Sheet.Copy After:=ThisWorkbook.Sheets(1) Next Sheet Workbooks(Filename).Close Filename = Dir() Loop Application.ScreenUpdating = True End Sub
How to Use this Code?
Here are the steps to use this code:
- Put all the Excel files that you want to combine into a folder. For the purpose of this tutorial, I have created a folder named Test and have six files in it (4 Excel workbooks and 1 Power Point and Word each).
- Open a new Excel workbook.
- Press ALT + F11 (or go to Developer –> Code –> Visual Basic). This will open the Visual Basic Editor.
- In the VB Editor, in the Project Editor, right-click on any of the objects for the workbook and go to Insert –> Module. This will insert a module for the workbook.
- Double click on the module. It will open the code window on the right.
- Copy and paste the above code into the code window.
- In the code, you need to change the following line of code:
FolderPath = Environ("userprofile") & "DesktopTest"
In this line, change the part in double quotes (highlighted in orange) with the location of the folder in which you have the files that you want to combine. In the code used above, the folder is on the Desktop. In case you have it in some other location, specify that path here.
- Place the cursor anywhere in the code and click on the green play button in the Toolbar options (or press the F5 key).
This will run the code and all the worksheets from all the Excel files in the folder would get consolidated into a single workbook.
How this Code Works?
- The code uses the DIR function to get the file names from the specified folder.
- The following line assigns the first excel file name to the variable ‘Filename’.
Filename = Dir(FolderPath & “*.xls*”) - Then the Do While loop is used to check whether all the files have been covered.
- Within the ‘Do While’ loop, ‘For Each’ loop is used to copy all the worksheets to the workbook in which we are running the code.
- At the end of the Do Loop, following line of code is used: Filename = Dir(). It assigns the next Excel file name to the Filename variable and the loop starts again.
- When all the files are covered, DIR function returns an empty string, which is when the loop ends.
Here is an explanation of the DIR function in the MSDN library:
Dir returns the first file name that matches pathname. To get any additional file names that match pathname, call Dir again with no arguments. When no more file names match, Dir returns a zero-length string (“”).
Have you ever tried something of this sort using VBA? Do share what you did and we all can learn from it.
Save a Crazy Amount of Time Using VBA. Check out the Excel VBA COURSE.
You May Also Like the Following Excel Tutorials:
98 thoughts on “How to Combine Multiple Excel Files into One Excel Workbook”
Brilliant thanks!
Highly frustrating – simply can’t get the damn thing to work….
I had this problem as well but fixed it as follows,
1. Save the document as .xlxm
2. Make sure you have a “/” at the end of your directory path
sorry .xlsm
The code works but the filepath string requires all of the “” in the complete file path. For example: C:UsersUser1DesktopExcelfiles*.xls*. This best way to solve this is:
When you modify the FolderPath = Environ(“userprofile”) & “DesktopTest” make sure you include the pre and post forward slashes “” to the folder path containing the excel sheets to be imported.
When you are debugging right click on the Folderpath and Filename variable and set them to the Watchlist with the Break when value changes box checked. When you run the program you can verify those two variables are updating correctly.
Thanks so much, worked perfectly.
Not working,It is showing debugg at Filename = Dir(FolderPath & “*.xlsx*”).
Can you please provide a fix
For this code to work some of you will likely need more than the suggested file path of:
FolderPath = Environ(“userprofile”) & “DesktopTest”
Environ(“userprofile”) will only provide the first part of a filepath. In my case it was: C:UsersWF. There were several subfolders “along the path” before getting to the folder I used for the files to be combined. Use this example as the path to the correct folder:
folderpath = “C:UsersWFDocumentsFolder1Folder2Folder3FolderWithFiles
For a convenient way to get the correct path use this code to place the path on a worksheet. Then copy/paste into the sub procedure.
Sub Path_FileName()
Dim strPath As String
strPath = ActiveWorkbook.FullName
ActiveCell.Value = strPath
End Sub
Make this adjustment if you need to. This is some very useful code.
I was getting error 52 as well.
“DESKTOP TEST” = LOCATION OF FILE
I changed this string of code (moved the parenthesis) from the below and it worked:
CHANGED FROM
FolderPath = Environ(“userprofile”) & “DesktopTest”
CHANGED TO
FolderPath = Environ(“userprofile” & “DesktopTest”)
Big thank you!! I had found various other versions of this code but this is the first one that worked for my version of Excel. Needed to combine over 30 spreadsheets and it saved me lots of time!
I am getting error 52 when I run the code.
Thanks alot. It was very helpful. I am a options trader needed it to backtest the things. So thanks again. Let me know how can I give it back to you.
Many thanks for this! Forty spreadsheets … into one without copy/pasting each sheet. Phew.
how can i add in the header in the active worksheet before I run this code? or i can do it at the same time?
I have followed the instructions carefully but i get an error of Bad filename 52
Great code and works! One thing though that may be tripping people up. The string Filename also is part of the Workbooks.Open Filename:= command. Anyone having issues with the Filename variable should try attempting to rename the string to something else to avoid issues. Least what I had to do for this to properly work for me.
I am having filename issues
fabulous!!! works amazing
Filename = Dir(FolderPath & “*.xls*”)
Sorry not working for me, gives me error on file dir.
Cant combine multiple files…no error shown,can we send you the sample files-please share your email id
Worked for me. Thank you so Much! saved me much time for a work project. Thank you so much for uploading
Like so many in this thread, this did not work for me – suggest it is taken down as a waste of valuable time!
That worked amazing! Thank you, thank you, thank you!
Heaps thanks worked just perfect.. you saved my time.
Hi , how can I combine the first worksheet of multiple Excel workbooks in a specified folder into a single Excel workbook ?
I have used this code but its is creating multiple tabs for the sheet with same name like Name (1); Name(2); Name(3)
Any solution
I am getting Run-time error Bad file name or number
I have used the path “H:Sheets”
Please advise
Delete the :
it didnt work, this came back as an error
Filename = Dir(FolderPath & “*.xls*”)
have you solve this case ? I have same error …
try putting “” at the end of folder path (note that in dos, between file name and the directory there has to be “” sign
I want to combine individual timesheets into one master file, but the t/s are protected. Will I still be able to enter data and save it?
I am getting debug in filename. Please help me
Remove the Environ(“userprofile”) & from your code. This just tells VBA to go to folders under your user. But if you already have something like “C:UsersVarunDocuments” in the folder path, this will throw the error you get.
Excellent !!!
Is it possible to name the sheets accordingly to their filenames?
Hi, i am getting debug in Filename.
Can you help me ?
Hie I have many workbook and i want to combine every second sheet from workbook together
Thanks for this tip Sumit………….
But it create multiple sub sheets of multiple files…what should to do if we need all multiple files into only one single sub sheet and i also want that the data copy should be in sequence
Not working for me. I followed all the steps mentioned above.
juse WPS office
sorry i just want to say. Use WPS Office
error 1004:
method ‘copy’ of object ‘ _worksheet’ failed
Debug =
Sheet.Copy After:=ThisWorkbook.Sheets(1)
Same issue with me.
not working this coding,
error on
Filename = Dir(FolderPath & “*.xls*”)
kindly slove this problem
I am getting the same error
I used ” ” and entered folder path where the file is located inside the quotation and it worked for me.
Hi I need some help in developing an extinction tool. Where 80 Percent can be done through formulas. Bit I need some help on remaining things. Will appreciate your help.
not working 🙂
need smart support
I am making an estimation tool. The first method worked, but that’s not dynamic.
I want the list to refresh if a new file is added to the folder.
Thanx a lot !!!!! Saved lot of time
Super!!!
Saved lot of time
hi can i update daily log sheets / material use sheet, warehouse sheet and combining into 1 for KPI ? daily folks save in same folder with different date and shift
Hi Sumit
It does’nt work for me after peressing the F5 I got ERE “BAD FILE NAME”
As I see numer of people here have had the same ERE plz explain the reason for it
What about copying different sheets from different excel files to one sheet by adding the new data to the old one ?
Thank you so much for this VBA code! Excellent time-saver!
Hi, I have to copy 4 sheets from different excel files in one excel.
Excel name in which i have to copy my data= Summary
Data copy from below listed excels
Excel 1= Los Angeles CCAP ASE Job Log Backup 15-11-18
Excel 2= Anaheim CCAP ASE Job Log Backup 15-11-18
Excel 3= BAY-North CCAP ASE Job Log Backup 15-11-18
Excel 4= San Diego CCAP ASE Job Log Backup 15-11-18
Now from every file, I have to copy only 1 sheet. names of sheets are mentioned below.
Excel 1 sheet name= LA
Excel 2 sheet name= Anaheim
Excel 1 sheet name= SD
Excel 1 sheet name= BayNorth
Please help I have to submit a report to my manager.
I have over 2000 files to combine. I did a test run of 100 and the result was garbage.
Did you ever find a solution? I am in a similar boat.
how to combine three workbook in one workbook easy and quick
I am getting error mentioning Run time error 52. Bad file name or number. For your information I have saved the files on my Desktop with a folder name as Test. Please suggest
I am getting an error as bad file name,can someone help me with this error,would be really thankful!
It doesn’t work for me, I have “bad file name or number”. do you know how to fix it?
helpful
very useful ,I like it very much !
When i press f5, nothing happens -! can anyone pls help ?
Attempting with CSV files. =) will let you know.
I have a query . Suppose I have to merge 652 workbooks into one. The filenames are 1.xlsx to 652.xlsx and i want to merge them in ascending order of their filenames only . Will this code merge it according to their sorted name in the folder or not ??
Hi Sumit, need your assistance with the above macro.
This works good if you want to combine multiple sheets in 1 workbook.
I need a solution where the following steps need to be done :
1. There are around 4000 employees and the workbook will be each employee code wise
2. There are 18 folders with workbooks with 1 worksheet for each employee.. there is a possibility that for an employee one of the workbooks will not be there
3. The macro should create a workbook with the emp code then across the 18 folders should check whether workbook is available for the employee ID and if yes
4. Copy and paste it in the created workbook and save.
5. Additionally there are 3 workbooks by default which need to be added for all employees
What i do not know to edit the above macro is:
1. How do i build a For loop for an employee list
2. If there is no specific excel workbook in one of the folder then it should not throw an error
Please help. I can communicate on your official email id too and will be happy if you can provide a solution at the earliest even if it is chargeable.
Regards
That’s great thanks. It would be even better if it named the sheets after the original file names.
yes
Still usable. You need to place a “/” after your path if you copy it in.
Thank you, this worked along with removing the Environ(“userprofile”) & code segment for FolderPath where I was able to combine 13 single sheet Excel files that I placed in a test folder on a mapped network drive (example: FolderPath = “Z:20198 – AUGMeeting AttendeesTest/”
The code is really work for me using in Excel 2016 after few experiments.
Some tips for those who are struggling about getting error message:
1) The code is worked for both xls and xlsx, don’t need to modify it.
2) The code ONLY works for worksheet, do try to move chart, you will get error. (anyone know how to move all together?)
3) Try 1 or 2 workbooks first to see whether it is work for you or not.
Hope these help you all 🙂
Wow first one actually worked:)
This did not work. Yes it combines 2 workbooks, but it destroys the functionality of the formulas in the process. Now, this could be me making some bad choices when it prompts me while the macro is running. Idk. Example: while macro was running I got several “name ‘use lists’ already exists. Yes to keep no to rename it something else” messages (sub ‘use lists’ with various other names). And regarding other formulas being destroyed, example: a simple =’TAB’!A1&” “&’TAB’!A2 type of formula is now bloated with file directory info. So it reads like:
=’C:UserEtcpathTAB’!A1&” “&’C:UserEtcpathTAB’!A2
That last one I can fix by deleting the stupid file directory info, formula by formula. As for the whole yes or no to renaming stuff that already exists… I’m at a loss.
TL;DR I don’t know VBA & this formula didn’t work in my scenario.
Sumit Bansal you Rock <3
Thanks for posting this! I’m getting “Run-time error ’52’: Bad file name or number” – anyone know how I can overcome this?
change .xls to .xl
I removed the “environment” as well
Need multiple files into one single sheet.
Hi, I was able to get the script above to work.
How can I modify this script to combined Sheets with the name “Sheet1” from multiple file into one file.
so how did you ended up making it work???
What am I missing? I keep getting a run time error 52 (bad file name or number) on this line: Filename = Dir(FolderPath & “*.xlsm*”). I changed it to .xlsm for Excel 2013 for macro.
Ugh…me too!!!
also, can I only combine page 1 of the workbooks to be combined into a single workbook?
If my files are on a network drive, do I remove the “Environ” part of the FolderPath?
It’s not working for me..!! When i am pressing F5…no combination of sheets..>!!
Thank you for the tip.
I have a question related to the handling the files with macros (*.xlsm) since the code will pick these files as well during the run. It seems that the macros will not be copied along with the worksheets and therefore some of the formulas may not work in the new workbook.
Thanks for commenting Lazarus.. You’re right! This wouldn’t pick up the macros while copying the sheets
is there any way if the multiple files can be consolidated into one single tab instead of multiple tabs?
Hi Sumit,
Also it is not working for me for “xlsx” file. It is showing debugg at Filename = Dir(FolderPath & “*.xlsx*”). Please get a solution. Thanks
I am getting the same error…..
Here When the Path In the Folder Is Copied It Must Start Form The “Desktop” & Not As “C:”
If Rectify This Then It Automatically Works When pressing “F5”
Here When the Path In the Folder Is Copied It Must Start Form The “Desktop” & Not As “C:”
If Rectify This Then It Automatically Works When pressing F5
Thanks for this tip Sumit………….
But it create multiple sub sheets of multiple files…what should to do if we need all multiple files into only one single sub sheet…………
Pls. help.
Hello Anand, By what I understand, You want to combine all the sheets from all the workbooks into a single sheet. This may be limited by the number of rows in a worksheet. It would be helpful if you could share a sample file
Hi Sumit,
Firstly Thanks for concern.
I have send an email to you for further clarification on it. Pls. have a look.
Hi Sumit………..
Pls. help on this…………