Copy a worksheet from one workbook to another workbook based on conditional statements

Pookiemeister

Well-known Member
Joined
Jan 6, 2012
Messages
626
Office Version
  1. 365
  2. 2010
Platform
  1. Windows
VBA Code:
Sub CopyWorkbook()

    Dim currentSheet as Worksheet
    Dim sheetIndex as Integer
    sheetIndex = 1

    For Each currentSheet in Worksheets

        Windows("SOURCE WORKBOOK").Activate 
        currentSheet.Select
        currentSheet.Copy Before:=Workbooks("TARGET WORKBOOK").Sheets(sheetIndex) 

        sheetIndex = sheetIndex + 1

    Next currentSheet

End Sub

I am needing to copy the data from one page of a workbook to another. I found this code on another forum but I can't get it to work with my code. The workbook that the data will be coming from is named "Maintenance Orders and Operations.xlsx". I'm not sure if I needed to add the .xlsx and it will be copied to workbook "WO Report Template 4.1.xlsm". The worksheet it will be copied to will be determined by the week number of the month. Example: We are currently in the first week in this month. So the worksheet is named "Past Due Week 1". Also, if the source workbook is named "Maintenance Orders" that should follow under the first conditional part. Thank you.

VBA Code:
Sub week_num()
    
      Dim WS_Count As Integer
      Dim I As Integer
      Dim WeekNum As Integer
      
      
      WS_Count = ActiveWorkbook.Worksheets.Count
      WeekNum = Application.WorksheetFunction.RoundUp(Day(Now()) / 7, 0)
      
            
      For I = 1 To WS_Count
      
         If ActiveWorkbook.Worksheets(I).Name = "WO Week " & (WeekNum) Then

         ElseIf ActiveWorkbook.Worksheets(I).Name = "Past Due Week " & (WeekNum) Then

         End If
         
      Next I
    
End Sub
 

Excel Facts

Back into an answer in Excel
Use Data, What-If Analysis, Goal Seek to find the correct input cell value to reach a desired result
Give this a go on a copy of your data.

It copies the sheet to the beginning of the target workbook.

Let you know if you want it at the end.

VBA Code:
Public Sub CopyWorkbook()

On Error GoTo Err_Handler

  With Workbooks("WO Report Template 4.1.xlsm")

    Application.DisplayAlerts = False
    On Error Resume Next
    .Sheets("Past Due Week " & WorksheetFunction.WeekNum(Date)).Delete
    On Error GoTo 0
    Application.DisplayAlerts = True
    
    On Error GoTo Err_Handler
    
    Workbooks("Maintenance Orders and Operations.xlsm").Sheets("TestWorksheet").Copy _
      Before:=.Sheets(1)
    
    .Sheets(1).Name = "Past Due Week " & WorksheetFunction.WeekNum(Date)
  
  End With
  
  Workbooks("Maintenance Orders and Operations.xlsm").Activate
    
Exit_Handler:

  Exit Sub

Err_Handler:
  
  MsgBox "There has been an error." & vbCrLf & vbCrLf & _
    "Error No: " & Err.Number & vbCrLf & _
    "Error Description: " & Err.Description, vbOKOnly, "Warning"
  
  Resume Exit_Handler
  
End Sub
 
Upvote 0
I tried this method I saw online but it came back with Runtime error '1004': Application-defined or object-defined error. On the following line of code.

VBA Code:
Workbooks("Maintenance Orders and Operations.xlsx").Worksheets(1).Range("A1:X").Copy Workbooks("WO Report Template 4.1.xlsm").Worksheets("Past Due Week " & WeekNum).Range("A1")

Here is all of it so far.
VBA Code:
Sub Week_Num_2()
    
    WeekNum = Application.WorksheetFunction.RoundUp(Day(Now()) / 7, 0)

    Workbooks("Maintenance Orders and Operations.xlsx").Worksheets(1).Range("A1:X").Copy Workbooks("WO Report Template 4.1.xlsm").Worksheets("Past Due Week " & WeekNum).Range("A1")
        
End Sub
 
Upvote 0
I tried this method I saw online but it came back with Runtime error '1004': Application-defined or object-defined error. On the following line of code.

VBA Code:
Workbooks("Maintenance Orders and Operations.xlsx").Worksheets(1).Range("A1:X").Copy Workbooks("WO Report Template 4.1.xlsm").Worksheets("Past Due Week " & WeekNum).Range("A1")

Here is all of it so far.
VBA Code:
Sub Week_Num_2()
   
    WeekNum = Application.WorksheetFunction.RoundUp(Day(Now()) / 7, 0)

    Workbooks("Maintenance Orders and Operations.xlsx").Worksheets(1).Range("A1:X").Copy Workbooks("WO Report Template 4.1.xlsm").Worksheets("Past Due Week " & WeekNum).Range("A1")
       
End Sub
Does this line ALWAYS give you the correct week number?
WeekNum = Application.WorksheetFunction.RoundUp(Day(Now()) / 7, 0)

Best to use the specific function WEEKNUM to get the week number?

Will the data ALWAYS come from the first sheet?

What range does Range("A1:X") give you?

Do you want all of the data from the first sheet?

Does the target worksheet ALWAYS exist?
 
Upvote 0
Does this line ALWAYS give you the correct week number?
WeekNum = Application.WorksheetFunction.RoundUp(Day(Now()) / 7, 0
Yes, for what I need it for.
Will the data ALWAYS come from the first sheet?
From Workbooks("Maintenance Orders and Operations.xlsx"). This workbook only contains one sheet. The actually sheet name is "SAPUI5 Export".
What range does Range("A1:X") give you?
I don't understand this question but the information needed will start from Range("A1:X#"). This data will change daily so the end row will change, that is why there is no number next to the letter "X" in the range. As the weeks increase, the end range will increase. Example below.
WeekNum=1 the range maybe Range("A1:X88").
WeekNum=5 the range maybe Range("A1:X175")
Do you want all of the data from the first sheet?
Yes
Does the target worksheet ALWAYS exist?
Yes
 
Upvote 0
Yes, for what I need it for.

From Workbooks("Maintenance Orders and Operations.xlsx"). This workbook only contains one sheet. The actually sheet name is "SAPUI5 Export".

I don't understand this question but the information needed will start from Range("A1:X#"). This data will change daily so the end row will change, that is why there is no number next to the letter "X" in the range. As the weeks increase, the end range will increase. Example below.
WeekNum=1 the range maybe Range("A1:X88").
WeekNum=5 the range maybe Range("A1:X175")

Yes

Yes
If that is all the case then which part of this code failed?

VBA Code:
        Sub Week_Num_2()
   
WeekNum = Application.WorksheetFunction.RoundUp(Day(Now()) / 7, 0)

Workbooks("Maintenance Orders and Operations.xlsx").Worksheets(1).Range("A1:X").Copy Workbooks("WO Report Template 4.1.xlsm").Worksheets("Past Due Week " & WeekNum).Range("A1")

End Sub
 
Upvote 0

Forum statistics

Threads
1,225,738
Messages
6,186,725
Members
453,368
Latest member
positivemind

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