Adding SaveAs/SaveCopyAs to my Macro

Jette3173

New Member
Joined
Oct 29, 2024
Messages
11
Office Version
  1. 365
Platform
  1. Windows
  2. Web
I have been working on a long/multiple macro and have finally gotten it where I want and decided it would be nice to add the final save as to the end.
I have two options that I have put together but neither work fully and I'm not sure what I am missing.
Please help and thank you for any guidance anyone can provide!!!

My goal is to take the macro enabled wb from my desktop folder and save it as a typical .xlsx wb on a shared drive.



Option 1: This saves as a file not as an excel sheet.

VBA Code:
    Dim wb As String
    wb = Left(ActiveWorkbook.Name, Len(ActiveWorkbook.Name) - 5)
   
   
    ActiveWorkbook.SaveAs Filename:= _
        "R:\Destination File Path\" & wb, FileFormat:=51, _
    CreateBackup:=False
       
    MsgBox "The file has been saved"


Option 2: This saves as a .xlsx, but upon opening the file states the extension is currupted.

VBA Code:
    Dim wb As String
    wb = Left(ActiveWorkbook.Name, Len(ActiveWorkbook.Name) - 5)
   
   
    ActiveWorkbook.SaveCopyAs Filename:= _
        "R:\Destination File Path\" & wb & ".xlsx"

    MsgBox "The file has been saved"
 

Excel Facts

Why are there 1,048,576 rows in Excel?
The Excel team increased the size of the grid in 2007. There are 2^20 rows and 2^14 columns for a total of 17 billion cells.
Option 1:
This saves as a file not as an excel sheet.
I don't understand what this means. If you save an Excel workbook, it's a file. When I run this I get a prompt asking if I want to save the file without macros. If I answer Save and Erase Features, it is correctly saved as a .xlsx file. Can you give more details about what result you are getting?

Although it's not an error, I prefer to use the enumeration names for built-in constants rather than the numbers. It documents the code better:
Rich (BB code):
    ActiveWorkbook.SaveAs Filename:= _
        "R:\Destination File Path\" & wb, FileFormat:=xlOpenXMLWorkbook, _
    CreateBackup:=False

Option 2:

SaveCopyAs does exactly that--saves an exact copy. You cannot use SaveCopyAs to save a .xlsm workbook as a .xlsx workbook. If you force the extension to be .xlsx, then when you try to open it Excel will realize it's a macro-enabled file with a .xlsx extension and treat it as invalid.
 
Upvote 0
Hello Jeff,
Thank you for helping me on this.
I have tried to look into the difference of SaveAs and SaveCopyAs and somehow didn't realize SaveCopyAs is an exact copy... (I feel smart)
That makes complete sense though and explains the extension corruption.

What I mean by file, is that is the 'extension' it is outputting. I do not receive any prompt asking if I want to save without macros. It just saves then when I check my folder it shows what I have attached.
I do have to close the excel file to delete the 'file' that was saved.


No change for using:
VBA Code:
    ActiveWorkbook.SaveAs Filename:= _
        "R:\HRD-HRIS\Compliance\2024\" & wb, FileFormat:=xlOpenXMLWorkbook, _
    CreateBackup:=False
 

Attachments

  • Screenshot 2024-11-18 110105.png
    Screenshot 2024-11-18 110105.png
    6.6 KB · Views: 7
  • Screenshot 2024-11-18 110838.png
    Screenshot 2024-11-18 110838.png
    4.9 KB · Views: 8
Upvote 0
Looks like you need to include the extension. Try this code, which I have tested successfully. Turning off alerts will force the file to be saved without prompting the user.

VBA Code:
    Application.DisplayAlerts = False
    
    ActiveWorkbook.SaveAs Filename:= _
        path & "\" & Replace(ActiveWorkbook.Name, ".xlsm", ".xlsx"), FileFormat:=xlOpenXMLWorkbook, _
    CreateBackup:=False
    
    Application.DisplayAlerts = True

If you want to fix the files you already have I think you can just rename them to add ".xlsx".
 
Upvote 0
Solution
Looks like you need to include the extension. Try this code, which I have tested successfully. Turning off alerts will force the file to be saved without prompting the user.

VBA Code:
    Application.DisplayAlerts = False
   
    ActiveWorkbook.SaveAs Filename:= _
        path & "\" & Replace(ActiveWorkbook.Name, ".xlsm", ".xlsx"), FileFormat:=xlOpenXMLWorkbook, _
    CreateBackup:=False
   
    Application.DisplayAlerts = True

If you want to fix the files you already have I think you can just rename them to add ".xlsx".
Thank you!!!!

If you dont mind me asking a question, why we need path & "\"
I appreciate you so much Jeff!
 
Upvote 0
The path must have a "\" before you add the filename. My code used

VBA Code:
    path = ActiveWorkbook.path
but I guess I didn't include that line of code in my example above. This does not have the "\" at the end so I had to add it.

In your original code you used
"R:\Destination File Path\"
which includes it, so it doesn't need to be added.
 
Upvote 0
Oh okay!
Thank you for explaining that! I had seen it before but it didn't make sense to me, I always thought in terms of including the "\" in the file path :)

Thank you again for your help!
 
Upvote 0

Forum statistics

Threads
1,225,730
Messages
6,186,701
Members
453,369
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