Answer: There are several "events" available within an Excel spreadsheet where you can place VBA code. In your case, we want to check for a duplicate value when the "Worksheet_Change" event fires.
Let's take a look at an example.
data:image/s3,"s3://crabby-images/46d34/46d3470cd340f2e2d6718585a92ce4f897a42400" alt=""
If the value is a duplicate, the following message will appear:
data:image/s3,"s3://crabby-images/430fa/430fa280a6ee5a57f85243fb5b9149eb53f90b55" alt=""
And the background color of the cell that contains the duplication will turn red.
data:image/s3,"s3://crabby-images/a4650/a465033a803c79ac04c61f8ec3ef2da59a4c23fc" alt=""
In this example, we've entered the value 1234 in cell A5 which already exists in cell A2.
You can press Alt-F11 to view the VBA code.
Macro Code:
The macro code looks like this:
Private Sub Worksheet_Change(ByVal Target As Excel.Range)
Dim LLoop As Integer
Dim LTestLoop As Integer
Dim Lrows As Integer
Dim LRange As String
Dim LChangedValue As String
Dim LTestValue As String
'Test first 200 rows in spreadsheet for uniqueness
Lrows = 200
LLoop = 2
'Check first 200 rows in spreadsheet
While LLoop <= Lrows
LChangedValue = "A" & CStr(LLoop)
If Not Intersect(Range(LChangedValue), Target) Is Nothing Then
If Len(Range(LChangedValue).Value) > 0 Then
'Test each value for uniqueness
LTestLoop = 2
While LTestLoop <= Lrows
If LLoop <> LTestLoop Then
LTestValue = "A" & CStr(LTestLoop)
'Value has been duplicated in another cell
If Range(LChangedValue).Value = Range(LTestValue).Value Then
'Set the background color to red
Range(LChangedValue).Interior.ColorIndex = 3
MsgBox Range(LChangedValue).Value & " already exists in cell A" & LTestLoop
Exit Sub
Else
Range(LChangedValue).Interior.ColorIndex = xlNone
End If
End If
LTestLoop = LTestLoop + 1
Wend
End If
End If
LLoop = LLoop + 1
Wend
End Sub
0 comments:
Post a Comment