I have a question about the using of Excel and VBA.
Let’s say in cell A1 and A2, I input 1 and 2. Then I input formula
“=SUM(A1 A2)” into cell A3.
I would like to write a VBA code to have the following functionality:
Once I change the formula in A3, let’s say I input 4 to cell A3, the
color of the cell A3 should be changed.
Once I double click the changed cell A3, it should recover to the
formula “=SUM(A1 A2)”.
Anybody could help me out to solve the problem?
Thank you--
jaccker
------------------------------------------------------------------------
jaccker's Profile: www.excelforum.com/member.php...oamp;userid=33116
View this thread: www.excelforum.com/showthread...hreadid=529223
Take a look at
www.cpearson.com/excel/events.htm
For a discussion on worksheet events.
---GJC--
gjcase
------------------------------------------------------------------------
gjcase's Profile: www.excelforum.com/member.php...oamp;userid=26061
View this thread: www.excelforum.com/showthread...hreadid=529223This might work for you
Dim prevVal
Const WS_RANGE As String = quot;A3quot;
'-----------------------------------------------------------------
Private Sub Worksheet_BeforeDoubleClick(ByVal Target As Range, Cancel As
Boolean)
'-----------------------------------------------------------------
If Not Intersect(Target, Me.Range(WS_RANGE)) Is Nothing Then
With Target
If .Interior.ColorIndex = 3 Then
.Formula = prevVal
.Interior.ColorIndex = xlColorIndexNone
End If
End With
End If
End Sub
'-----------------------------------------------------------------
Private Sub Worksheet_Change(ByVal Target As Range)
'-----------------------------------------------------------------
On Error GoTo ws_exit:
Application.EnableEvents = False
If Not Intersect(Target, Me.Range(WS_RANGE)) Is Nothing Then
With Target
.Interior.ColorIndex = 3 'red
End With
End If
ws_exit:
Application.EnableEvents = True
End Sub
'-----------------------------------------------------------------
Private Sub Worksheet_SelectionChange(ByVal Target As Range)
'-----------------------------------------------------------------
If Not Intersect(Target, Me.Range(WS_RANGE)) Is Nothing Then
With Target
If .HasFormula Then
prevVal = .Formula
End If
End With
End If
End Sub
'This is worksheet event code, which means that it needs to be
'placed in the appropriate worksheet code module, not a standard
'code module. To do this, right-click on the sheet tab, select
'the View Code option from the menu, and paste the code in.--
HTH
Bob Phillips
(remove nothere from email address if mailing direct)
quot;jacckerquot; gt; wrote in
message ...
gt;
gt; I have a question about the using of Excel and VBA.
gt;
gt; Let's say in cell A1 and A2, I input 1 and 2. Then I input formula
gt; quot;=SUM(A1 A2)quot; into cell A3.
gt;
gt; I would like to write a VBA code to have the following functionality:
gt;
gt; Once I change the formula in A3, let's say I input 4 to cell A3, the
gt; color of the cell A3 should be changed.
gt; Once I double click the changed cell A3, it should recover to the
gt; formula quot;=SUM(A1 A2)quot;.
gt;
gt; Anybody could help me out to solve the problem?
gt;
gt; Thank you
gt;
gt;
gt; --
gt; jaccker
gt; ------------------------------------------------------------------------
gt; jaccker's Profile:
www.excelforum.com/member.php...oamp;userid=33116
gt; View this thread: www.excelforum.com/showthread...hreadid=529223
gt;
- Dec 18 Thu 2008 20:48
an interesting Excel question
close
全站熱搜
留言列表
發表留言