VBA to override typed workbook name on save

kgartin

Board Regular
Joined
May 6, 2010
Messages
201
Is there a way to write a VBA code in a sheet that will override any name a user enters when a workbook is saved? I want the sheet to pull the name from a cell instead of accepting the name they type in because they never name the file properly.
 

Excel Facts

Workdays for a market open Mon, Wed, Friday?
Yes! Use "0101011" for the weekend argument in NETWORKDAYS.INTL or WORKDAY.INTL. The 7 digits start on Monday. 1 means it is a weekend.
Try this code in the ThisWorkbook module. If the user tries to 'Save As', the dialogue isn't displayed and instead the workbook is saved with the file name in cell A1 of Sheet1, in the same folder as the code workbook.

Code:
Private Sub Workbook_BeforeSave(ByVal SaveAsUI As Boolean, Cancel As Boolean)
    
    If SaveAsUI Then
        Cancel = True
        Application.EnableEvents = False
        Application.DisplayAlerts = False
        ThisWorkbook.SaveAs ThisWorkbook.Path & "\" & Worksheets("Sheet1").Range("A1").Value & ".xlsm"
        Application.DisplayAlerts = True
        Application.EnableEvents = True
    End If
    
End Sub
 
Upvote 0

Forum statistics

Threads
1,214,599
Messages
6,120,449
Members
448,966
Latest member
DannyC96

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