Partialy Change Font Color to Another Color

greenculture

New Member
Joined
Dec 7, 2013
Messages
26
this code change the red font color to green font color.... it is working code but getting error msg can you solve this


HTML:
Public Sub FontColorInCellPart()

Dim c As Range
Dim i As Integer

For Each cell In ActiveSheet.UsedRange
   
   For i = 1 To Len(cell)
      If cell.Characters(i, 1).Font.color = RGB(255, 0, 0) Then
         cell.Characters(i, 1).Font.color = RGB(0, 255, 0)
      
      End If
   Next i
Next cell

End Sub
 

Excel Facts

How to show all formulas in Excel?
Press Ctrl+` to show all formulas. Press it again to toggle back to numbers. The grave accent is often under the tilde on US keyboards.
Last edited by a moderator:
Upvote 0
Try...
Code:
Dim cell As Range Dim i As Integer  For Each cell In ActiveSheet.UsedRange
        For i = 1 To Len(cell)
       If cell.Characters(i).Font.color = RGB(79, 129, 189) Then
          cell.Characters(i).Font.color = RGB(255, 0, 0)
        End If
    Next i
 Next cell  End Sub

Denis
 
Upvote 0
It works if you step backwards through the characters:
Code:
Sub foo()
Dim c As Range
Dim sText As String
Dim i As Integer

For Each c In Cells.SpecialCells(xlCellTypeConstants, xlTextValues)
    sText = c.Value
    For i = Len(sText) To 1 Step -1
        If c.Characters(i, 1).Font.Color = RGB(0, 255, 0) Then
            c.Characters(i, 1).Font.Color = RGB(255, 0, 0)
        End If
    Next i
Next c
End Sub

Denis
 
Upvote 0
@sydneygeek ur code is working thanks your help

Try............

It works if you step backwards through the characters:
Code:
Sub foo()
Dim c As Range
Dim sText As String
Dim i As Integer

For Each c In Cells.SpecialCells(xlCellTypeConstants, xlTextValues)
    sText = c.Value
    For i = Len(sText) To 1 Step -1
        If c.Characters(i, 1).Font.Color = RGB(0, 255, 0) Then
            c.Characters(i, 1).Font.Color = RGB(255, 0, 0)
        End If
    Next i
Next c
End Sub

Denis
 
Upvote 0
Replace font color for part of text
Examples will show you how to change Font Color in Excel
Change Font Color Green to Red


Code:
Sub foo()
Dim c As Range
Dim sText As String
Dim i As Integer

For Each c In Cells.SpecialCells(xlCellTypeConstants, xlTextValues)
    sText = c.Value
    For i = Len(sText) To 1 Step -1
        If c.Characters(i, 1).Font.color = RGB( 0, 255, 0) Then
            c.Characters(i, 1).Font.color = RGB(255, 0, 0)
        End If
    Next i
Next c
End Sub
Change font color (full)
Code:
Sub ChangeFontColor()
Dim c As Range
For Each c In ActiveSheet.UsedRange
'(u can replace this For Each cell In Selection)
    If c.Font.ColorIndex = 1 Then
        c.Font.ColorIndex = 16
    End If
Next c
End Sub
 
Last edited by a moderator:
Upvote 0

Forum statistics

Threads
1,215,054
Messages
6,122,895
Members
449,097
Latest member
dbomb1414

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