close

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;

arrow
arrow
    全站熱搜
    創作者介紹
    創作者 software 的頭像
    software

    software

    software 發表在 痞客邦 留言(0) 人氣()