Understanding Scope for Named Ranges

by Allen Wyatt
(last updated November 4, 2017)

Chuck can easily set up named ranges in a workbook, and Excel allows him to specify whether that named range should apply to the whole workbook or to a single worksheet. He wonders, though, about the pros and cons of limiting the scope of a named range to a single worksheet. That leads to the question of whether it is better than leaving the scope set to the entire workbook.

As Chuck implies, the default for a named range is that it applies to the entire workbook. For most people this is just fine, and it reflects the way that most people work with named ranges. There is no "performance hit" associated with either workbook scope or worksheet scope, so that (fortunately) does not enter into the equation.

So when should you veer from the default and, instead, choose to make a named range applicable to only a worksheet? The obvious answer is when you have a worksheet that you may want to duplicate within a workbook, the worksheet contains named ranges that refer to ranges on that worksheet, and that worksheet contains formulas that utilize those named ranges. When you duplicate the worksheet, you'll want those formulas on the multiple worksheets to still work relative to their worksheets. If the named ranges are limited in scope to the worksheet, then everything should work as expected.

If you duplicate a worksheet that includes named ranges that use the "workbook" scope, and that copy is within the same workbook, Excel makes a change in the copied worksheet. Specifically, to prevent confusion in the workbook namespace, Excel automatically converts the named ranges in the copy to have worksheet scope. The named ranges in the original worksheet remain unchanged and, therefore, retain a workbook scope.

If you duplicate a worksheet that includes named ranges that use the "workbook" scope, and that copy is placed in a different workbook, then Excel only modifies the scope of those ranges if keeping the original scope would cause a conflict with any named ranges already existing in the target workbook.

In all cases, you'll want to double-check any formulas in your worksheets to make sure that they refer to what you expect them to refer to. Conversely, you can change the named range scope to "worksheet" before doing the worksheet copying so that there is less chance of confusion with the duplicated or copied worksheets.

You should note two potential gotchas, though, when using named ranges scoped for a particular worksheet. First, when you start duplicating the worksheet, you make it a bit more difficult for a user to track down potential problems because of identically named ranges on different worksheets. (It just takes a bit more for the user to wrap their head around the limited scope.)

Second, it can make your macros more complex, if those macros access named ranges. If you have such macros, you'll want to test them thoroughly to make sure that they reference the expected ranges. If you don't, the macros may mess up your worksheet data or crash altogether.

ExcelTips is your source for cost-effective Microsoft Excel training. This tip (4633) applies to Microsoft Excel 2007, 2010, 2013, and 2016.

Author Bio

Allen Wyatt

With more than 50 non-fiction books and numerous magazine articles to his credit, Allen Wyatt is an internationally recognized author. He is president of Sharon Parq Associates, a computer and publishing services company. ...

MORE FROM ALLEN

The Standard on the Ruler

Need to know all there is to know about the Ruler? This tip leads to a valuable Word MVP article on the subject.

Discover More

Adding Sidebars

When designing your document, you may want to use sidebars like you see in magazines and some books. This tip explains ...

Discover More

Adjusting Values with Formulas

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 More

Professional Development Guidance! Four world-class developers offer start-to-finish guidance for building powerful, robust, and secure applications with Excel. The authors show how to consistently make the right design decisions and make the most of Excel's powerful features. Check out Professional Excel Development today!

More ExcelTips (ribbon)

Last Non-Zero Value in a Row

If you have a lot of values in a single row, you might want to pull the last non-zero value from that row. There are a ...

Discover More

Breaking Up Variable-Length Part Numbers

Part numbers can often be long, made up of other component elements. Breaking up part numbers into individual components ...

Discover More

Changing the Reference in a Named Range

Define a named range today and you may want to change the definition at some future point. It's rather easy to do, as ...

Discover More
Subscribe

FREE SERVICE: Get tips like this every week in ExcelTips, a free productivity newsletter. Enter your address and click "Subscribe."

View most recent newsletter.

Comments

If you would like to add an image to your comment (not an avatar, but an image to help in making the point of your comment), include the characters [{fig}] in your comment text. You’ll be prompted to upload your image when you submit the comment. Maximum image size is 6Mpixels. Images larger than 600px wide or 1000px tall will be reduced. Up to three images may be included in a comment. All images are subject to review. Commenting privileges may be curtailed if inappropriate images are posted.

What is 3 + 5?

There are currently no comments for this tip. (Be the first to leave your comment—just use the simple form above!)


This Site

Got a version of Excel that uses the ribbon interface (Excel 2007 or later)? This site is for you! If you use an earlier version of Excel, visit our ExcelTips site focusing on the menu interface.

Newest Tips
Subscribe

FREE SERVICE: Get tips like this every week in ExcelTips, a free productivity newsletter. Enter your address and click "Subscribe."

(Your e-mail address is not shared with anyone, ever.)

View the most recent newsletter.