简体   繁体   中英

How does one restore default case to a variable in VBA (Excel 2010)?

At some point I accidentally named a variable range (all lower-case) and since then the Visual Basic for Applications editor refuses to use Range (Pascal-cased); it will auto-correct it to lower-case. How can I reset its "brain" to forget about my past transgression?

NOTE: I've tried doing a global replace-all, but the moment I edit any single line -- it re-corrects once again.

Obviously this is a very very minor, cosmetic issue but watching the R go limp every time I type Range is irritating.

You need to change the name of the variable in a declaration line ( Dim statement for example) somewhere (anywhere, actually).

This is one of the most annoying "features" of the VBA IDE (as if version control weren't already hard enough with VBA, the constant case-changing drives me batty). Variables have their case changed globally in the VBA IDE, regardless of the variable's actual scope. The VBA IDE seems to take the approach of most recent declaration wins.

Usually all you need to do is just update the case in a declaration line somewhere, but VBA can be obstinate. I've yet to crack the code completely.

Note: As @Scorchio points out in the comments below, the variable case is changed globally within the current project; other projects that may be open in the VBA IDE (such as other workbooks when working in Excel) are NOT affected.

UPDATE: I expanded on this entry in my Access/VBA blog today: VBA's Case Changing "Feature"

Last declaration in time wins.

  1. Go on first line and type Dim Range As String
  2. Move to next line
  3. Go back and remove your Dim Range As String

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM