我有一个表,表中有许多列和行,我想跟踪在特定列中所做的更改。我在网上找到了代码(请参阅消息底部),并且效果很好。但是,它跟踪“所有更改”。有没有办法使其范围特定。例如,我只想跟踪带有红色数字的列中所做的更改。请参见示例:
我在网上找到的代码如下:
Option Explicit
Dim vOldVal 'Must be at top of module
Private Sub Workbook_SheetChange(ByVal Sh As Object, ByVal Target As Range)
Dim bBold As Boolean
If Target.Cells.Count > 1 Then Exit Sub
If ActiveSheet.Name = "Pricing" Then Exit Sub
'On Error Resume Next
With Application
.ScreenUpdating = False
.EnableEvents = False
End With
If IsEmpty(vOldVal) Then vOldVal = "Empty Cell"
bBold = Target.HasFormula
With Sheets("Data")
'.Unprotect Password:="Secret"
If .Range("A96") = vbNullString Then
.Range("A96:H96") = Array("Cell Changed", "Old Value", _
"New Value", "Old Formula", "New Formula", "Time of Change")
End If
With .Cells(.Rows.Count, 1).End(xlUp)(2, 1)
.Value = ActiveSheet.Name & " : " & Target.Address
.Offset(0, 1) = vOldVal
With .Offset(0, 2)
If bBold = True Then
.ClearComments
.AddComment.Text Text:= _
"OzGrid.com:" & Chr(10) & "" & Chr(10) & _
"Bold values are the results of formulas"
End If
.Value = Target
.Font.Bold = bBold
End With
.Offset(0, 3) = Time
.Offset(0, 4) = Date
.Offset(0, 5) = Application.UserName
End With
.Cells.Columns.AutoFit
'.Protect Password:="Secret"
End With
vOldVal = vbNullString
With Application
.ScreenUpdating = True
.EnableEvents = True
End With
On Error GoTo 0
End Sub
Private Sub Workbook_SheetSelectionChange(ByVal Sh As Object, ByVal Target As Range)
vOldVal = Target
End Sub
Private Sub test()
Application.EnableEvents = True
End Sub
请记住,我是VBA编码的新手。
答案 0 :(得分:0)
您可以通过在现有代码中添加一行来实现:
Private Sub Workbook_SheetChange(ByVal Sh As Object, ByVal Target As Range)
Dim bBold As Boolean
If Target.Cells.Count > 1 Then Exit Sub
If ActiveSheet.Name = "Pricing" Then Exit Sub
If Target.Column <> 4 Then Exit Sub
这只会检查您的工作表的第4列是否已更改,并且将忽略其他位置的更改。