Excel Howto?
Excel VBA how to?
-Aviral Mittal
data:image/s3,"s3://crabby-images/66828/668287dd8511e04d68c5c1c86f28ae9e0e8574ad" alt=""
1. How to report repeat values in a column?
Sometimes a repeated value in a Colum isn't desired.
A function is presented below which will report if a value has been
repeated in a column.
Following this function, 2 Subroutines are presented, first does not
report an error, as there is no repetition,
and the second reports an error, as "London" is repeated in Column B
(2) as shown below:
This function can also take in Optionally the Sheet Name as input,
to search in a named sheet!
The search Column Number is also Optional. If not given, it defaults
to 1.
data:image/s3,"s3://crabby-images/df759/df759285ebc0950470b9809bdb4f5919d497c249" alt=""
Function FindRowAddr(RepeatString As
String, Optional colNum As Long, Optional shtName As String)
As String
'The function reports multiple occurences of
'RepeatString' as error.
'Example 1 : colNum = FindRowAddr("London", 1,
"Sheet1"), where colNum is of type long
'Example 2 : colNo = FindRowAddr(RepeatString:="Paris",
RowNum:=1, shtName:="Lists")
'Example 3 : colNo = FindRowAddr(RepeatString:="Zurich",
shtName:="Lists")
'Finds only 1 occurence of the RepeatString, if more are
present, it reports error
Dim sht As Worksheet
Dim mCell As Range
FindRowAddr = "$0$0" 'default return value.
If (shtName = "") Then
shtName = "Sheet1"
End If
On Error GoTo errorHandler
Set sht = ThisWorkbook.Worksheets(shtName)
sht.Activate
If colNum = 0 Then
colNum = 1
End If
Set mCell =
Columns(colNum).Find(What:=RepeatString, lookat:=xlWhole)
'searchStr is the string which is being searched
If mCell Is Nothing Then
Debug.Print "ERROR! From Function
'FindRowAddr': RepeatString " & "'" & RepeatString
& "'" & " not found in sheet '" & shtName &
"'"
MsgBox "ERROR! From Function
'FindRowAddr': RepeatString " & "'" & RepeatString
& "'" & " not found in sheet '" & shtName &
"'"
Exit Function
Else
FindRowAddr = mCell.Address
'Debug.Print "INFO: From Function
'FindRowAddr': Found '" & RepeatString & "' Address =
" & mCell.Address & " In Sheet '" & shtName &
"'"
End If
Dim firstCellAddress As String
firstCellAddress = mCell.Address
Dim ii As Long
ii = 0
Do
ii = ii + 1
If (ii > 1) Then
Debug.Print "ERROR! Sheet
" & "'" & shtName & "'" & " has multiple
occurence of " & "'" & RepeatString & "' at: "
& mCell.Address
MsgBox "ERROR! Sheet "
& "'" & shtName & "'" & " has multiple
occurence of " & "'" & RepeatString & "' at: "
& mCell.Address
FindRowAddr = "$0$0"
End If
Set mCell =
Columns(colNum).FindNext(mCell)
Loop While firstCellAddress <>
mCell.Address
Exit Function
errorHandler:
Debug.Print "ERROR! From Function 'FindRowAddr':
Sheet " & "'" & shtName & "'" & " Does not
exist"
MsgBox "ERROR! From Function 'FindRowAddr': Sheet
" & "'" & shtName & "'" & " Does not exist"
End Function
Sub TryReportRepeatValue()
'This
will search in Col 1 and will not report an error.
Dim RepeatString As String
Dim searchColNum As Long
searchColNum = 1
RepeatString = "London"
Dim iRowAddr As Long
'the following will try to find
"London" in Colmun 1 of "Sheet"
iRowAddr =
Split(FindRowAddr(RepeatString, searchColNum, "Sheet1"),
"$")(2)
If (iRowAddr = 0) Then
Debug.Print "ERROR_0004:
Multiple Init Error Occured"
Exit Sub
Else
MsgBox "Found " &
RepeatString & " at Row Number = " & iRowAddr
End If
End Sub
Sub TryReportRepeatValue_1()
'This
will search in Col 2 and report an error, as "London" is
repeated
Dim RepeatString As String
Dim searchColNum As Long
searchColNum = 2
RepeatString = "London"
Dim iRowAddr As Long
'the following will try to find
"London" in Colmun 1 of "Sheet"
iRowAddr =
Split(FindRowAddr(RepeatString, searchColNum, "Sheet1"),
"$")(2)
If (iRowAddr = 0) Then
Debug.Print "ERROR_0004:
Multiple Init Error Occured"
Exit Sub
Else
MsgBox "Found " &
RepeatString & " & at Row Number = " & iRowAddr
End If
End Sub
WB with the above code can be downloaded Here:
Book6.xlsm
<-
Previous
Next ->
Key Words: Excel Find repeat value. How to know if
there are multiple values in same column