Excel.Tips.Net Welcome toExcel.Tips.Net

Helpful Links

Tips.Net Home
ExcelTips Home
Ask an Excel Question
Make a Comment

Tips.Net Store

ExcelTips FAQ
ExcelTips Premium

Learn Access Now
Free Printable Forms

Beauty Tips
Car Tips
Cleaning Tips
College Tips
Cooking Tips
Excel2007 Tips
ExcelTips
Family Tips
Gardening Tips
Health Tips
Home Tips
Legal Tips
Money Tips
Organizing Tips
Pest Tips
Pet Tips
Wedding Tips
Word2007 Tips
WordTips

Advertise on the
ExcelTips Site

Newest Tips

Converting to Octal

Filtering Columns for Unique Values

Printing Multiple Worksheets on a Single Page

Changing the Default Font

Creating a Drawing Object

Determining a Value of a Cell

Understanding Macros

 

Offering Options in a Macro

Summary: It is often helpful to get user input within a macro. Here's a quick way to present some options and get the user's response. (This tip works with Microsoft Excel 97, Excel 2000, Excel 2002, Excel 2003, and Excel 2007.)

If you are just starting out developing macros, you may be looking for a simple way to offer a set of choices to a user, and then take an action based on the user's response. This is a relatively simple task, if you use the InputBox function along with a Select Case structure.

The first task is to set up your InputBox so it displays the information to the user. For example, let's say you have five options and you want the user to select one option from those five. You can use the following code to put together five options, each on their own line:

Prompt = "1. This is your first choice" + vbCrLf
Prompt = Prompt + "2. This is your second choice" + vbCrLf
Prompt = Prompt + "3. This is your third choice" + vbCrLf
Prompt = Prompt + "4. This is your fourth choice" + vbCrLf
Prompt = Prompt + "5. This is your fifth choice"

You can now use the Prompt string when you invoke the InputBox function in your macro. You then translate what the user responds with into a number that represents their choice from your five options. The code to do this is as follows:

UserResp = InputBox(Prompt, "The Big Question")
UR = Val(UserResp)

In this example, the response from the InputBox function is assigned to the UserResp variable, which should be a string. The UR variable, which is a numeric, is then set based on the value of the string. (The Val function returns the value in a string.)

The only thing left to do is to take an action based on which number was chosen, 1 through 5. You can use the Select Case structure to do this. The full subroutine could appear as follows:

Sub Macro1()
    Dim Prompt As String
    Dim UserResp As String
    Dim UR As Single

    Prompt = "1. This is your first choice" + vbCrLf
    Prompt = Prompt + "2. This is your second choice" + vbCrLf
    Prompt = Prompt + "3. This is your third choice" + vbCrLf
    Prompt = Prompt + "4. This is your fourth choice" + vbCrLf
    Prompt = Prompt + "5. This is your fifth choice"
    UR = 0
    While UR < 1 Or UR > 5
        UserResp = InputBox(Prompt, "The Big Question")
        UR = Val(UserResp)
    Wend
    Select Case UR
        Case 1
            'Do stuff for choice 1 here
        Case 2
            'Do stuff for choice 2 here
        Case 3
            'Do stuff for choice 3 here
        Case 4
            'Do stuff for choice 4 here
        Case 5
            'Do stuff for choice 5 here
    End Select
End Sub

Notice that this example uses a While ... Wend loop around the InputBox function. This is done to make sure that the user enters a number between 1 and 5. If the value entered is outside that range, then the user is simply asked again.

ExcelTips is your source for cost-effective Microsoft Excel training. This tip (3098) applies to Microsoft Excel versions: 97 | 2000 | 2002 | 2003 | 2007

Save Time and Money! Many people need to keep track of employee time, but don't know where to start when it comes to creating a spreadsheet. Here's a way to save time, effort, and money with ready-to-use timesheet templates.
 
Check out Timesheet Templates today!