VBA to change the text color only for numbers

gberg

Board Regular
Joined
Jul 16, 2014
Messages
206
Office Version
  1. 365
Platform
  1. Windows
Is there a way to have a macro only change the color of numbers for the selected cells?

51Alpha3 would turn into 51Alpha3

Thanks
 

Excel Facts

Formula for Yesterday
Name Manager, New Name. Yesterday =TODAY()-1. OK. Then, use =YESTERDAY in any cell. Tomorrow could be =TODAY()+1.
Hi gberg,

Try this:

VBA Code:
Option Explicit
Sub Macro1()

    Dim rngCell As Range
    Dim i As Long
    
    Application.ScreenUpdating = False
    
    For Each rngCell In Selection
        For i = 1 To Len(rngCell)
            rngCell.Characters(i, 1).Font.Color = IIf(IsNumeric(Mid(rngCell, i, 1)), vbRed, vbBlack)
        Next i
    Next rngCell
    
    Application.ScreenUpdating = True

End Sub

Regards,

Robert
 
Upvote 0
Solution
Trebor,

That did the trick! Thanks for the help with this. One question; What do you need the "Option Explicit" before the start of the sub?

Thanks,

Greg
 
Upvote 0
That did the trick! Thanks for the help with this.

Thanks for letting us know and you're welcome (y)

One question; What do you need the "Option Explicit" before the start of the sub?

Option Explicit forces you to declare all variables as I have done with the two I used for your solution. Without it any undeclared variable(s) will be defined as variants which is the most expensive type of variable in terms of memory which can impact performance.
Hope that helps.
 
Upvote 0
Option Explicit forces you to declare all variables as I have done with the two I used for your solution. Without it any undeclared variable(s) will be defined as variants which is the most expensive type of variable in terms of memory which can impact performance.
Hope that helps.
There is a far better reason for using Option Explicit than variable declaration efficiency... it will save you from accidentally mistyping a variable name deep within your code. If you do not declare a variable as to its data type, then the first time you use a new variable anywhere within your code, VBA creates it then and there... declaring it as a variant. The major thing Option Explicit saves you from is that "then and there" creation. Here is an example. Assume you do not have Option Explicit activated...

MYVARIABLE = 100
MYVARIABLE = 5 * MYVAR1ABLE
Debug.Print MYVARIABLE

The intent of this code is to print 500, but it prints 0 instead. The problem is easy to see here because of the font this forum uses, but copy/paste that code into a procedure in a code window within the VBA editor and I bet you would have trouble seeing it. Now imagine that calculation was taking place in your code, but instead of printing the result to the Immediate Window, you went on to use the MYVARIABLE in more calculations. You would **think** that further calculation was using 500, not 0 and unless the final result from the procedure was so far off as to draw your attention, you would never know an error took place at all and, as a result, you would be basing any decisions from that code on an incorrect answer. Option Explicit saves you from this kind of mistyped variable name by forcing you to declare all variables and it makes VBA raise an error when it encountered an undeclared variable such as MYVAR1ABLE in the code above.
 
Upvote 0
Thanks Rick. I will flag this thread as a go to for any future threads asking why using Option Explicit should be used.

Regards,

Robert
 
Upvote 0

Forum statistics

Threads
1,225,876
Messages
6,187,541
Members
453,429
Latest member
JeanDuarnet

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top