Excel.Tips.Net ExcelTips (Menu Interface)

Changing Font Face and Size Conditionally

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: Changing Font Face and Size Conditionally.

Robin asks if there is a way to use Excel's conditional formatting capabilities to change the font used in a cell or to change the font size in a cell. The short answer is no, that can't be done—at least not with conditional formatting. (The controls that allow you to specify font name and size are grayed-out in the formatting dialog box used with conditional formatting.)

You can, however, use a macro to examine cell contents and make changes in the appearance of a cell. Consider the following macro, which examines any cells you have selected when you run the macro. If any of the cells have a length of more than two characters or a value of more than 10, then the cell's font is changed.

Sub DoReformat()
    Dim rCell As Range

    For Each rCell In Selection.Cells
        If Len(rCell.Text) > 2 Or _
          Val(rCell.Value) > 10 Then
            rCell.Font.Name = "Arial"
            rCell.Font.Size = 16
            rCell.Font.Name = "Times New Roman"
            rCell.Font.Size = 12
        End If
End Sub

To use the macro, just select the cells you want changed and then run the macro. If you want the formatting to change more automatically, then you can have the macro check to see if a change was made within a certain range of cells:

Private Sub Worksheet_Calculate()
    Dim rng As Range
    Dim rCell As Range

    Set rng = Range("A1:A10")

    For Each rCell In rng
        If Len(rCell.Text) > 2 Or _
          Val(rCell.Value) > 10 Then
            rCell.Font.Name = "Arial"
            rCell.Font.Size = 16
            rCell.Font.Name = "Times New Roman"
            rCell.Font.Size = 12
        End If
End Sub

This macro, when added to the worksheet object, will run every time the worksheet is recalculated. It checks the range A1:A10, applying the same tests as in the previous macro. The result is that the formatting of the cells is checked and changed continuously. To have the macro check a different range, just change the addresses assigned to the rng variable near the beginning of the macro.

One drawback of this macro is that it can get sluggish if you have a very large range for it to check. It will go very quickly if you are checking A1:A10 (ten cells), but may go much slower if you are continually checking B2:N465 (over 6,000 cells). In that case, you may want to design the macro so it runs whenever the worksheet is changed, but only takes action if the change was done to a cell in your target range. The following version is also added to the worksheet object:

Private Sub Worksheet_Change(ByVal Target As Range)
    Dim rCell As Range

    If Union(Target, Range("A1:A10")).Address = _
      Range("A1:A10").Address Then
        Application.EnableEvents = False
        For Each rCell In Target
            If Len(rCell.Text) > 2 Or _
              Val(rCell.Value) > 10 Then
                rCell.Font.Name = "Arial"
                rCell.Font.Size = 16
                rCell.Font.Name = "Times New Roman"
                rCell.Font.Size = 12
            End If
        Application.EnableEvents = True
    End If
End Sub

The macro uses the Union function to check whether the cells changed (passed to the event handler in the Target variable) have any overlap with the range you want checked. If they do, then the checking is done on the cells in the Target range.

One thing to keep in mind with macros that affect formatting is that if you have conditional formatting applied to a cell that is also checked by a macro, the formatting in the conditional formatting takes precedence over the formatting in the macro. If your macro is changing font name and font size, this isn't a big concern because conditional formatting won't affect these attributes. However, if you change your macro to also change a different format attribute—such as cell color—and that attribute is also changed by the conditional format, then it won't look like the macro did anything because Excel uses the conditional formatting in preference to what the macro does.

ExcelTips is your source for cost-effective Microsoft Excel training. This tip (2380) 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: Changing Font Face and Size Conditionally.

Related Tips:

Create Custom Apps with VBA! Discover how to extend the capabilities of Office 2013 (Word, Excel, PowerPoint, Outlook, and Access) with VBA programming, using it for writing macros, automating Office applications, and creating custom applications. Check out Mastering VBA for Office 2013 today!


Leave your own comment:

  Notify me about new comments ONLY FOR THIS TIP
Notify me about new comments ANYWHERE ON THIS SITE
Hide my email address
*What is 5+3 (To prevent automated submissions and spam.)
           Commenting Terms

Comments for this tip:

Kevin    05 Jan 2017, 14:54
I want to use a macro to change the font size of numbers within a cell. See example:


This is Chinese text and the numbers indicate pronunciation tone. If the cell is formatted to size 16 then the numbers are too large. I would like to reduce the number size to 10 and leave the text at 16.

Thanks for your help. Kevin
Barry    17 Oct 2014, 09:31

What you ask for is quite easily done.

You would need to be a bit more specific before any code could be written. In Jeff's example, he specified the controlling range is column A and the controlled range is the entire row containing the changed controlling cell, and the change criteria is the word "Large".
Barry    17 Oct 2014, 09:20

The following macro will do what you want it needs to be placed on the codepage of the worksheet that you want it to operate on.

Private Sub Worksheet_Change(ByVal Target As Range)

    If Target.Range("A1").Column <> 1 Then Exit Sub
        With Target.Range("A1")
            If LCase(.Value) = "large" Then
                .EntireRow.Font.Name = "Arial"
                .EntireRow.Font.Size = 16
                .EntireRow.Font.Name = "Times New Roman"
                .EntireRow.Font.Size = 12
            End If
        End With
End Sub
Jeff    16 Oct 2014, 17:07
Is there a way to apply a change to an entire row? And can it be applied based on whether a cell contains a string of text? For example, in range A4:L10, I want to enlarge the font size for each row in which the cell in column A contains the word "Large".
Alex    06 Oct 2014, 12:33
This code was very helpful. One further question though: what about VBA code that will change the font of a range of cells based on the values of a different range? Is that possible?

Dicu-Sava Cristian    17 Oct 2013, 21:52
First macro (Sub DoReformat), work only with text.
What about working with text and numbers ?
I tryed to change Text with Characters but ... got an error. :)

Mad    16 May 2013, 11:11
Thanks for that tips!
I'm able in Excel, but not very good at programming in VBA. But this will help me alot in my personal files. They will look better.

Thanks again :)

Our Company

Sharon Parq Associates, Inc.

About Tips.Net

Contact Us


Advertise with Us

Our Privacy Policy

Our Sites


Beauty and Style




DriveTips (Google Drive)

ExcelTips (Excel 97–2003)

ExcelTips (Excel 2007–2016)



Home Improvement

Money and Finances


Pests and Bugs

Pets and Animals

WindowsTips (Microsoft Windows)

WordTips (Word 97–2003)

WordTips (Word 2007–2016)

Our Products

Helpful E-books

Newsletter Archives


Excel Products

Word Products

Our Authors

Author Index

Write for Tips.Net

Copyright © 2017 Sharon Parq Associates, Inc.