Color active cell

I am using the following macro in one work sheet and it works very well, but it won't not work in another worksheet, why?
VBA Code:
Private Sub Worksheet_SelectionChange(ByVal Target As Range)
    Cells.Interior.ColorIndex = xlNone
    ActiveCell.Interior.ColorIndex = 6
End Sub
Missed this one
To ThisWrokbook code moodule.
Code:
Private Sub Workbook_SheetSelectionChange(ByVal Sh As Object, ByVal Target As Range)
    Dim cf As FormatCondition, r As Range
    For Each cf In Sh.Cells.FormatConditions
        If cf.Type = 2 Then
            If cf.Formula1 Like "=ADDRESS(*" Then cf.Delete
        End If
    Next
    For Each r In Target
        r.FormatConditions.Add 2, Formula1:="=address(row(),column())=""" & r.Address & """"
        r.FormatConditions(1).Interior.Color = vbYellow
        r.FormatConditions(1).StopIfTrue = False
    Next
End Sub
 
Upvote 0

Excel Facts

Quick Sum
Select a range of cells. The total appears in bottom right of Excel screen. Right-click total to add Max, Min, Count, Average.
Missed this one
To ThisWrokbook code moodule.
Code:
Private Sub Workbook_SheetSelectionChange(ByVal Sh As Object, ByVal Target As Range)
    Dim cf As FormatCondition, r As Range
    For Each cf In Sh.Cells.FormatConditions
        If cf.Type = 2 Then
            If cf.Formula1 Like "=ADDRESS(*" Then cf.Delete
        End If
    Next
    For Each r In Target
        r.FormatConditions.Add 2, Formula1:="=address(row(),column())=""" & r.Address & """"
        r.FormatConditions(1).Interior.Color = vbYellow
        r.FormatConditions(1).StopIfTrue = False
    Next
End Sub
I would definitely not use that code!
  1. If a large range is selected it causes my Excel to stop responding. After all, with say 5 columns selected there would be over 5,000,000 individual cell conditional formats to apply! (And then when something else was selected there would be over 5,000,000 individual cell conditional formats to delete)

  2. With my test sheets if I already had some existing conditional formatting applied, this code altered the colour of my existing CF to the yellow.

  3. The code results in the loss of the ability to use Excel's Undo function.

Point 1 above is actually not too much of a problem because the OP actually asked for the Active Cell to be highlighted not the Active Selection. So that code could be modified to just the Active Cell - but the issues in points 2 and 3 would still exist.


My suggestion is this, which overcomes all 3 of the above points.

A. Remove any codes that you have been trying in relation to this task from the ThisWorkbook module or individual sheet modules

B. For one of the relevant worksheets, select the whole worksheet (by clicking the box at the top left at the intersection of the column labels and row labels). We could select a lesser range but applying it to the whole worksheet doesn't seem to make files too big or slow in my experience.

C. Use Conditional Formatting -> New rule.. -> Use a formula to determine ... -> Format values where this formula is true: =AND(CELL("col")=COLUMN(),CELL("row")=ROW()) -> Format... -> On the Fill tab select the colour you want** for the Active cell -> Ok -> Ok

D. Repeat steps B and C for each worksheet where you might want the Active Cell highlighted. If there is a lot of sheets, a code could be written to do this as a once-off task.

E. Copy and Paste the code below into the ThisWorkbook module

F. Close the Visual Basic window & test.

VBA Code:
Private Sub Workbook_SheetSelectionChange(ByVal Sh As Object, ByVal Target As Range)
  Application.ScreenUpdating = True
End Sub

** When choosing a colour, better to choose a colour that is not already used on the worksheet. On the Fill tab in the CF set-up if you go to 'More Colors...' it would be easy to make a colour unique for your sheet. With my method above, if it would help, you can use different colours on different worksheets for the Active Cell highlights. For example if you had multiple 'Income' type sheets you might want to use a shade of green and for 'Expense' type sheets you might want to use a yellow etc.
 
Upvote 0
I am using the following macro in one work sheet and it works very well, but it won't not work in another worksheet, why?
Rich (BB code):
Private Sub Worksheet_SelectionChange(ByVal Target As Range)
    Cells.Interior.ColorIndex = xlNone
    ActiveCell.Interior.ColorIndex = 6
End Sub
Rich (BB code):
Private Sub Workbook_SheetSelectionChange(ByVal Sh As Object, ByVal Target As Range)
    Dim cf As FormatCondition, r As Range
    For Each cf In Sh.Cells.FormatConditions
        If cf.Type = 2 Then
            If cf.Formula1 Like "=ADDRESS(*" Then cf.Delete
        End If
    Next
    With ActiveCell
        .FormatConditions.Add 2, Formula1:="=address(row(),column())=""" & .Address & """"
        .FormatConditions(1).Interior.Color = vbYellow
        .FormatConditions(1).StopIfTrue = False
    End With
End Sub
	
	
	
	
	
	


Code:
 
Upvote 0
have tried them all,t none of them work. What i do not understand is why i use the same code from a working sheet to another worksheet it does not work
 
Upvote 0
Here is a link to a sample file. Try downloading that file and test. (Sorry, did not spell you user name correctly when naming the file. :oops:)
alfonsoro1.xlsm
 
Upvote 0
have tried them all,t none of them work. What i do not understand is why i use the same code from a working sheet to another worksheet it does not work

You tried the code from post #4.

I'll put it back to you.

But first you must delete your code and put the following code, but in thisworkbook events

VBA Code:
Private Sub Workbook_SheetSelectionChange(ByVal Sh As Object, ByVal Target As Range)
Cells.Interior.ColorIndex = xlNone
ActiveCell.Interior.ColorIndex = 6
End Sub

ThisWorkbook EVENT
- Open the VB Editor (press Alt + F11).
- Over in the Project Explorer, double click on ThisWorkbook.
- In the white panel that then appears, paste the above code.
 
Upvote 0
BTW, you did not address this question. :)
@alfonsoto1
Might any of your cells in any of your worksheets already contain colour for some reason? If so this code will wipe that colour out. If you do (or might) have other colours already in the sheet(s), other alternatives are available.

One further question. Do you have, or might you have, any Conditional Formatting at all (not necessarily only for cell colour) in any of the worksheets in the workbook?
 
Upvote 0
have tried them all,t none of them work. What i do not understand is why i use the same code from a working sheet to another worksheet it does not work
The code I posted should be paced in ThisWorkbook code modue.
Whle you are in vbe, double click on ThisWorkbook from Project Explorer and paste the code.
 
Upvote 0

Forum statistics

Threads
1,225,760
Messages
6,186,868
Members
453,380
Latest member
ShaeJ73

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