Problems with "Find" looking for dates"

GrumpyOldGit

New Member
Joined
Jun 28, 2012
Messages
13
I'm trying to develop a function to locate a date in a specific column in a spreadsheet (Excel 2010).
I've tried lots of variations but still get "Nothing" as a Find result.
The Worksheet (Sheet1) has column "B" formatted as "Date". In B2 I have "=NOW()". In B3 to B30 I have "=Bx+1", so each cell holds the next day's date.
The Worksheet (Sheet1) has column "C" formatted as "General". In C2 I have 1. In C3 to C30 I have "=Cx+1", so each cell holds the next number.

In the following code which calls the Locator subroutine to find a Number, then a Date, the Number search works, but the Date search fails.

I've tried all sorts of methods for matching the formats of what I'm searching for to what I'm looking at, but to no avail.

Can anyone help me to get this code working? (I think I'm getting the same problems with different "location" routines (e.g. "Application.Worksheetfunction.Match") which gives me an "Unable to get the Match property of the Worksheetfunction class" error.)

Any help would be gratefully appreciate by a head sore from repeated bashings on a brick wall!

Code:
Option Explicit
Sub Tester()
Dim varSearchFor                As Variant
  varSearchFor = 30
  Call Locator("C", varSearchFor)
  varSearchFor = CLng(DateValue("17/01/2013"))
  Call Locator("B", varSearchFor)
End Sub
Sub Locator(strColLetter As String, _
            varSearchFor As Variant, _
            Optional strSheetName As String = "Sheet1")
Dim rngSearch                   As Range
Dim varResult                   As Variant
Dim strSearchFor                As String
Dim shtSheet                    As Worksheet
Dim lngLastRow                  As Long
Dim rngCell                     As Range
Dim strRange                    As String
Dim lngSearchFor                As Long
'*
'** Get the range of used cells for the supplied column.
'** We assume we're dealing with "Sheet1".
'*
  Set shtSheet = Sheets(strSheetName)
  lngLastRow = shtSheet.Range(strColLetter & Rows.Count).End(xlUp).Row
  
  strRange = strColLetter & "2:" & _
             strColLetter & lngLastRow
  Set rngCell = shtSheet.Range(strRange).Find(What:=varSearchFor, _
                LookIn:=xlValues, _
                LookAt:=xlPart, _
                SearchOrder:=xlByRows, _
                SearchDirection:=xlNext, _
                MatchCase:=False, _
                SearchFormat:=False)
  If Not rngCell Is Nothing Then
    Call MsgBox("Searching for " & varSearchFor & vbCrLf & _
                "rngCell = " & rngCell & vbCrLf & _
                "Address = " & rngCell.Address, _
                vbInformation, _
                "DIAGNOSTIC")
   Else
    Call MsgBox("Cannot find " & varSearchFor & vbCrLf & _
                "in the range " & strRange, _
                vbCritical, _
                "DIAGNOSTIC")
  End If
End Sub

Steve
 

Excel Facts

When they said...
When they said you are going to "Excel at life", they meant you "will be doing Excel your whole life".
I HATE YOU ANDREW!!!

I've spent two days using different code to (not) achieve my aim, and in under 15 minutes you've solved it. And I thought I was pretty good!

Seriously, and sincerely, thanks a lot. For anyone too idle to follow your link, and in case it ever gets broken, I've included the working code below.
Code:
Option Explicit
Sub Tester()
Dim varSearchFor                As Variant
  varSearchFor = 30
  Call Locator("C", varSearchFor)
  varSearchFor = "17/01/2013"
  Call DateLocator("B", varSearchFor)
End Sub
Sub Locator(strColLetter As String, _
            varSearchFor As Variant, _
            Optional strSheetName As String = "Sheet1")
Dim rngSearch                   As Range
Dim varResult                   As Variant
Dim strSearchFor                As String
Dim shtSheet                    As Worksheet
Dim lngLastRow                  As Long
Dim rngCell                     As Range
Dim strRange                    As String
Dim lngSearchFor                As Long
'*
'** Get the range of used cells for the supplied column.
'** We assume we're dealing with "Sheet1".
'*
  Set shtSheet = Sheets(strSheetName)
  lngLastRow = shtSheet.Range(strColLetter & Rows.Count).End(xlUp).Row
  
  strRange = strColLetter & "2:" & _
             strColLetter & lngLastRow
  Set rngCell = shtSheet.Range(strRange).Find(What:=varSearchFor, _
                LookIn:=xlValues, _
                LookAt:=xlPart, _
                SearchOrder:=xlByRows, _
                SearchDirection:=xlNext, _
                MatchCase:=False, _
                SearchFormat:=False)
  If Not rngCell Is Nothing Then
    Call MsgBox("Searching for " & varSearchFor & vbCrLf & _
                "rngCell = " & rngCell & vbCrLf & _
                "Address = " & rngCell.Address, _
                vbInformation, _
                "DIAGNOSTIC")
   Else
    Call MsgBox("Cannot find " & varSearchFor & vbCrLf & _
                "in the range " & strRange, _
                vbCritical, _
                "DIAGNOSTIC")
  End If
End Sub
Sub DateLocator(strColLetter As String, _
                varSearchFor As Variant, _
                Optional strSheetName As String = "Sheet1")
Dim rngSearch                   As Range
Dim varResult                   As Variant
Dim strSearchFor                As String
Dim shtSheet                    As Worksheet
Dim lngLastRow                  As Long
Dim rngCell                     As Range
Dim strRange                    As String
Dim lngSearchFor                As Long
'*
'** Get the range of used cells for the supplied column.
'** We assume we're dealing with "Sheet1".
'*
  Set shtSheet = Sheets(strSheetName)
  lngLastRow = shtSheet.Range(strColLetter & Rows.Count).End(xlUp).Row
  
  strRange = strColLetter & "2:" & _
             strColLetter & lngLastRow
  Set rngCell = shtSheet.Range(strRange).Find(What:=DateValue(varSearchFor), _
                LookIn:=xlValues, _
                LookAt:=xlWhole, _
                SearchOrder:=xlByRows, _
                SearchDirection:=xlNext, _
                MatchCase:=False, _
                SearchFormat:=False)
  If Not rngCell Is Nothing Then
    Call MsgBox("Searching for " & varSearchFor & vbCrLf & _
                "rngCell = " & rngCell & vbCrLf & _
                "Address = " & rngCell.Address, _
                vbInformation, _
                "DIAGNOSTIC")
   Else
    Call MsgBox("Cannot find " & varSearchFor & vbCrLf & _
                "in the range " & strRange, _
                vbCritical, _
                "DIAGNOSTIC")
  End If
End Sub
 
Upvote 0

Forum statistics

Threads
1,223,228
Messages
6,170,875
Members
452,363
Latest member
merico17

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top