VBA code for save as and close workbook

Jonathan Jones

New Member
Joined
Jul 30, 2017
Messages
18
Hi,

I would like to save the active workbook as a specific name which is obtained from a cell in the workbook, then close the workbook.

It's a test results sheet. The engineer opens the master, he adds his results and then clicks a button which says "Testing Complete". I'd like the master to be closed without saving, then the one he's added his results to is saved as a value in a cell to a specific folder on the server and then closed. Ideally, I'd like a warning box to come up which says "Testing Complete?" with an option of yes or no. No, cancels, yes proceeds with the above process.

I have just started to learn VBA, so I was hoping to work it out for myself but I need this for something at work, and have got impatient!

Any help, would be very much appreciated.

Jonathan
 

Excel Facts

Format cells as currency
Select range and press Ctrl+Shift+4 to format cells as currency. (Shift 4 is the $ sign).
In the simplest form, if your file path is on Sheet1 in cell A1:

Rich (BB code):
Public Sub TestingComplete()
  Dim answer As VBA.VbMsgBoxResult
  
  answer = MsgBox("Testing complete?", vbYesNo + vbQuestion, "Confirm")
  If answer = vbNo Then Exit Sub
  
  ThisWorkbook.SaveCopyAs Sheet1.Range("A1").Value
  
  ' add any other code before this line
  ThisWorkbook.Close savechanges:=False
 
End Sub
 
Last edited:
Upvote 0
In the simplest form, if your file path is on Sheet1 in cell A1:

Rich (BB code):
Public Sub TestingComplete()
  Dim answer As VBA.VbMsgBoxResult
  
  answer = MsgBox("Testing complete?", vbYesNo + vbQuestion, "Confirm")
  If answer = vbNo Then Exit Sub
  
  ThisWorkbook.SaveCopyAs Sheet1.Range("A1").Value
  
  ' add any other code before this line
  ThisWorkbook.Close savechanges:=False
 
End Sub

Hi,

Thanks very much for such a quick reply. I just have a couple of questions. 1. Your code doesn't seem to specify what file type the document is saved as, I would like it to be saved as just a standard excel file format without macros enabled (although it's not the end of the world if achieving this is overly complicated). 2. I can't see in your code where the folder the file is saved in is specified (this is important).

Thanks,

Jonathan
 
Upvote 0
change this ThisWorkbook.SaveCopyAs Sheet1.Range("A1").Value

to

ThisWorkbook.SaveCopyAs Sheet1.Range("A1").Value & ".xlsx", FileFormat:=51 ', CreateBackup:=False
 
Upvote 0
If you use SaveCopyAs, you can't specify the file format (because if it's different, then it's not a copy). If it needs to be different, then you need to use SaveAs.

To specify the path,

Code:
  ThisWorkbook.SaveCopyAs "C:\somePath\" & Sheet1.Range("A1").Value
 
Upvote 0
If you use SaveCopyAs, you can't specify the file format (because if it's different, then it's not a copy). If it needs to be different, then you need to use SaveAs.

I thought about this too. I think it depends on how exactly you want to structure your workflow, and what you want the experience to be like for the end user.

If you use SaveAs, then the "master" workbook is essentially closed, and the new file is in front of the user. But, you can specify the file format.

If you use SaveCopy As, then the new file is saved in its location (in the same file format), and the master workbook is still shown to the user. You can then choose to close the master workbook, but have the option not to.

If you want the best of both worlds - i.e. specify file format, and close the new file and still show the master workbook) - then you would need to do a SaveAs, re-open the master workbook, and close the newly saved-as file. This is a little more cumbersome, especially if the files are large and saved on the network (saving/re-opening will not be instantaneous), it degrades the user experience because there will be a "please wait" type flicker on the screen. But it can be done, if that's what you're trying to accomplish.
 
Last edited:
Upvote 0
I would do SaveCopyAs, open the new file, and then SaveAs in whatever format was desired.
 
Upvote 0

Forum statistics

Threads
1,225,357
Messages
6,184,469
Members
453,235
Latest member
dirtisbrown17

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