Please Note: This article is written for users of the following Microsoft Excel versions: 97, 2000, 2002, and 2003. If you are using a later version (Excel 2007 or later), this tip may not work for you. For a version of this tip written specifically for later versions of Excel, click here: Running a Procedure when a Workbook is Opened.
You can cause Excel to run a procedure automatically whenever a particular workbook is opened. For instance, when the workbook is opened, you might want to run a procedure that asks the users if they want to perform some task, such as saving the previous day's data to another file.
In order to run a procedure automatically when a workbook is opened, all you need to do is name the procedure Auto_Open(). Thus, the following procedure will be run automatically whenever the workbook containing it is opened:
Sub Auto_Open()
Dim strMsg As String
Dim intBoxType As Integer
Dim strTitle As String
Dim intUpdate As Integer
Dim strDefault As String
Dim strOldFile As String
Dim intStatusState As Integer
strMsg = "Do you want to save yesterday's transactions?"
intBoxType = vbYesNo + vbQuestion
strTitle = "Automatic Backup Routine"
intUpdate = MsgBox(Msg, BoxType, Title)
If intUpdate = vbYes Then
strMsg = "Which filename would you like use?"
strDefault = "OLD.DAT"
strOldFile = InputBox(strMsg, strTitle, strDefault)
intStatusState = Application.DisplayStatusBar
Application.DisplayStatusBar = True
Application.StatusBar = "Updating past months..."
UpdateYesterday
Application.StatusBar = False
Application.DisplayStatusBar = intStatusState
End If
End Sub
(Remember that this procedure is an example; it won't run properly on your system because it calls a function called UpdateYesterday, which does the actual updating.)
This macro runs automatically whenever the workbook to which it is attached is opened. You could also modify the code and place it within the ThisWorkbook object simply by changing the first line to this:
Private Sub Workbook_Open()
Many people consider using Auto_Open as the "old way" of this type of macro and Workbook_Open as the "new way." In a sense that is true; the Workbook_Open method is a more object-oriented approach to this type of macro than is Auto_Open. In practice, however, there is very little difference between the two.
Note:
ExcelTips is your source for cost-effective Microsoft Excel training. This tip (2289) applies to Microsoft Excel 97, 2000, 2002, and 2003. You can find a version of this tip for the ribbon interface of Excel (Excel 2007 and later) here: Running a Procedure when a Workbook is Opened.
Best-Selling VBA Tutorial for Beginners Take your Excel knowledge to the next level. With a little background in VBA programming, you can go well beyond basic spreadsheets and functions. Use macros to reduce errors, save time, and integrate with other Microsoft applications. Fully updated for the latest version of Office 365. Check out Microsoft 365 Excel VBA Programming For Dummies today!
Paste Special is a great tool that allows you to modify the values in a range of cells in your worksheets. You may want, ...
Discover MoreWhen storing text in a worksheet, you may have a need to change the case of that text so that the initial letter in each ...
Discover MoreMacros are great for working with strings, and one of the most commonly used string functions is Len. This tip explains ...
Discover MoreFREE SERVICE: Get tips like this every week in ExcelTips, a free productivity newsletter. Enter your address and click "Subscribe."
There are currently no comments for this tip. (Be the first to leave your comment—just use the simple form above!)
Got a version of Excel that uses the menu interface (Excel 97, Excel 2000, Excel 2002, or Excel 2003)? This site is for you! If you use a later version of Excel, visit our ExcelTips site focusing on the ribbon interface.
FREE SERVICE: Get tips like this every week in ExcelTips, a free productivity newsletter. Enter your address and click "Subscribe."
Copyright © 2025 Sharon Parq Associates, Inc.
Comments