VBA Macro to copy only ACTIVE Sheet to new workbook as xslm and new location

dinkss

Board Regular
Joined
Aug 25, 2020
Messages
129
Office Version
  1. 365
  2. 2016
Platform
  1. Windows
Hi there,

I have a macro like this which saves workbook to new location, and works fine. But I need to change this code to save only ACTIVE Sheet, not all of them. Basically I need macro to do 1 to 1 copy of active sheet in different location and will rename the file to original workbook name with date and time. Can anyone help me with this?

Sub SAVE_TO_ARCHIVE()
' Saves active file to current plus backup location, appends system date and time in front of file name in backup locations.

Dim datim As String
datim = Format(CStr(Now), "yyyy_mm_dd_hh_mm_ss_")

ActiveWorkbook.SaveCopyAs "E:\****pack\KAROL_KITPACK_DOWNTIME_TEMP\ARCHIVE\" & datim & ActiveWorkbook.Name
ActiveWorkbook.Save

MsgBox "You can find archived files in E:\****pack\KAROL_KITPACK_DOWNTIME_TEMP\ARCHIVE\ " & FolderName
Application.ScreenUpdating = True
End Sub
 

Excel Facts

Can a formula spear through sheets?
Use =SUM(January:December!E7) to sum E7 on all of the sheets from January through December
Hi dinkiss,

where does foldername in your macro get it`s value?

Code for the ActiveSsheet may look like this
VBA Code:
Sub SAVE_ACTIOVESHEET_TO_ARCHIVE()
' Saves active sheet to current plus backup location, appends system date and time in front of file name in backup locations.
'https://www.mrexcel.com/board/threads/vba-macro-to-copy-only-active-sheet-to-new-workbook-as-xslm-and-new-location.1171883/

Dim datim As String
Dim strWbName As String

Const cstrPATH As String = "E:\****pack\KAROL_KITPACK_DOWNTIME_TEMP\ARCHIVE\"
datim = Format(Now, "yyyy_mm_dd_hh_mm_ss_")
strWbName = ActiveWorkbook.Name

ActiveSheet.Copy
ActiveWorkbook.SaveAs cstrPATH & datim & strWbName, FileFormat:=51
ActiveWorkbook.Close False

MsgBox "You can find archived worksheet in " & cstrPATH & datim & strWbName
'Application.ScreenUpdating = True
End Sub
Ciao,
Holger
 
Upvote 0
Hi dinkiss,

where does foldername in your macro get it`s value?

Code for the ActiveSsheet may look like this
VBA Code:
Sub SAVE_ACTIOVESHEET_TO_ARCHIVE()
' Saves active sheet to current plus backup location, appends system date and time in front of file name in backup locations.
'https://www.mrexcel.com/board/threads/vba-macro-to-copy-only-active-sheet-to-new-workbook-as-xslm-and-new-location.1171883/

Dim datim As String
Dim strWbName As String

Const cstrPATH As String = "E:\****pack\KAROL_KITPACK_DOWNTIME_TEMP\ARCHIVE\"
datim = Format(Now, "yyyy_mm_dd_hh_mm_ss_")
strWbName = ActiveWorkbook.Name

ActiveSheet.Copy
ActiveWorkbook.SaveAs cstrPATH & datim & strWbName, FileFormat:=51
ActiveWorkbook.Close False

MsgBox "You can find archived worksheet in " & cstrPATH & datim & strWbName
'Application.ScreenUpdating = True
End Sub
Ciao,
Holger
I'll try that and will update you!

What do you mean by saying: where foldername in your macro get it`s value?
 
Upvote 0
Hi dinkss,

inside the procedure you posted the variable foldername is only mentioned with the message box. As it is not referenced inside the procedure it should get a value elsewhere as a module wide or global variable or it will be empty (and have no effect on the display of MsgBox). That´s all.

Ciao,
Holger
 
Upvote 0
Hi dinkss,

inside the procedure you posted the variable foldername is only mentioned with the message box. As it is not referenced inside the procedure it should get a value elsewhere as a module wide or global variable or it will be empty (and have no effect on the display of MsgBox). That´s all.

Ciao,
Holger
Oh OK. Thank you buddy! I will test your macro and will let you know! Thanks for the help!
 
Upvote 0
Oh OK. Thank you buddy! I will test your macro and will let you know! Thanks for the help!
Hi buddy, I tried your macro but it gives me an error, have a look at these screenshots.
Any help with this?
 

Attachments

  • debug error.png
    debug error.png
    37 KB · Views: 11
  • debug error2.png
    debug error2.png
    29.3 KB · Views: 11
Upvote 0
Hi dinkss,

my bad - FileFormat 51 stands for xlOpenXMLWorkbook (without macro's in 2007-2016, xlsx), it must be 52 (xlOpenXMLWorkbookMacroEnabled (with or without macro's in 2007-2016, xlsm)).

Ciao,
Holger
 
Upvote 0
Hi dinkss,

my bad - FileFormat 51 stands for xlOpenXMLWorkbook (without macro's in 2007-2016, xlsx), it must be 52 (xlOpenXMLWorkbookMacroEnabled (with or without macro's in 2007-2016, xlsm)).

Ciao,
Holger
It works perfectly buddy! WOW, thanks so much!

Can you tell me please - if I use this macro:

Sub BBK_AUTO_SAVE()
Application.OnTime Now + TimeValue("01:00:00"), "BBK_AUTO_SAVE"

ActiveWorkbook.Save

End Sub

Do I need to create a button for it and assign macro or once inserted as a module will it save active workbook every 1 hour?
 
Upvote 0
Hi dinkss,

I would call the macro from ThisWorkbook and Workbook_Open and get the timer started once the workbook is opened. I´d also make sure that the timer will be deactivated when the workbook is closed.

Ciao,
Holger
 
Upvote 0
Hi dinkss,

I would call the macro from ThisWorkbook and Workbook_Open and get the timer started once the workbook is opened. I´d also make sure that the timer will be deactivated when the workbook is closed.

Ciao,
Holger
OMG, that's too complicated for me :( could you help me with this?

What MACRO exacly I have to insert, and where?

I would love to have your knowledge!
 
Upvote 0

Forum statistics

Threads
1,225,466
Messages
6,185,146
Members
453,279
Latest member
MelissaOsborne

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