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: Generating Random Testing Data.
Written by Allen Wyatt (last updated July 9, 2022)
This tip applies to Excel 97, 2000, 2002, and 2003
When you develop worksheets that will be used by other people, you should test those worksheets to make sure that they work as you expect. This is particularly true of worksheets that contain complex formulas or will be used for critical purposes. The concept of testing a worksheet means that you will need to generate some sort of data to use in testing the worksheet.
Entire books have been written on putting together testing suites for software. How rigorous you are in compiling test data depends, in large part, on the needs of your audience and the nature of your worksheet. Unfortunately, there is no quick cure-all that will automatically figure out what you need and generate the data for you. There are tools in Excel, however, that you can use toward this end.
First, if you need to generate random numeric values, you can use the RAND or RANDBETWEEN worksheet functions. The difference is that RAND generates a value between 0 and 1, and RANDBETWEEN generates integer values between any bounds you set.
Random data may not be appropriate for your testing needs, however. This is particularly true when you are testing boundaries of your formulas. For instance, testing with large values, small values, or a combination of large and small values. Likewise, you may want to test for inappropriate values, such as using text as input rather than numbers (or vice versa). There are a whole contingent of conditions you need to think through, and then pick the type of data that is right for your needs.
If you prefer, you can use macros to generate testing data. The following macro fills a selected range of cells with a random numeric value, between whatever boundaries (minimum and maximum) that you set.
Sub RandNums()
Dim MyRange As Range
Dim lMin As Long, lMax As Long
Dim dRand As Double
' If selection is not Excel Range
If TypeName(Selection) <> "Range" Then Exit Sub
Set MyRange = Selection
' Get Min and Max value
lMin = CLng(InputBox("Minimum?"))
lMax = CLng(InputBox("Maximum?"))
Randomize
Application.ScreenUpdating = False
For Each c In MyRange.Cells
' Calculate random value, where
' Value >= Min And Value <= Max
dRand = Rnd * (lMax - lMin) + lMin
' Use the following line only if the random
' value should be an integer
' dRand = Int(dRand)
c.Value = dRand
Next c
Application.ScreenUpdating = True
End Sub
To use the macro, just select a range of cells that you want to contain random numeric values, and then run the macro. If you must use integer values in the cells, then you can "uncomment" the noted line within the macro.
If you want to fill a range of cells with random dates, then a slight modification to the RandNums macro results in the following.
Sub RandDates()
Dim MyRange As Range
Dim dtMin As Date, dtMax As Date
Dim dtRand As Date
' If selection is not Excel Range
If TypeName(Selection) <> "Range" Then Exit Sub
Set MyRange = Selection
' Get Min and Max value
' From: 1/1/1990 (put your start Date)
dtMin = #1/1/1990#
' To: Today
dtMax = Date
Randomize
Application.ScreenUpdating = False
For Each c In MyRange.Cells
' Calculate random value, where
' Value >= Min And Value <= Max
dtRand = Rnd * (dtMax - dtMin) + dtMin
dtRand = Int(dtRand)
c.Value = dtRand
' Change format for cell, below, as desired
c.NumberFormat = "m/d/yyyy"
Next c
Application.ScreenUpdating = True
End Sub
Again, just select a range and then run the macro. You can modify the initial values set to the dtMin and dtMax variables in order to specify the boundaries for the dates desired. You can also, if desired, change the formatting applied to the cells after the random date is stored within the cells.
Note:
ExcelTips is your source for cost-effective Microsoft Excel training. This tip (2077) 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: Generating Random Testing Data.
Program Successfully in Excel! This guide will provide you with all the information you need to automate any task in Excel and save time and effort. Learn how to extend Excel's functionality with VBA to create solutions not possible with the standard features. Includes latest information for Excel 2024 and Microsoft 365. Check out Mastering Excel VBA Programming today!
When looking at a number, you may wonder how many significant digits it contains. The answer is not always an easy one, ...
Discover MoreNeed to understand who is using a particular workbook? There are a number of ways you can find out, as discussed in this tip.
Discover MoreDo you need to know how many times a worksheet has been used? Excel doesn't track that information, but you can develop ...
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