Runtime Error 424 - not sure why.

JeffGrant

Well-known Member
Joined
Apr 7, 2021
Messages
558
Office Version
  1. 365
Platform
  1. Windows
Hi All,

I have this code to loop through a column in a table to check if the string value for time is earlier than the current string value of now. Hever, I am getting a 424 error and I don't know why.

I am getting the Run-Time error 424: Object required from the For Each cell in column.DataBodyRange line.

This is my code:

VBA Code:
Sub SkipEarlierTimes()

    Dim ws As Worksheet
    Dim tbl As ListObject
    Dim column As ListColumn
    Dim cell As Variant
    Dim currentTime As Date

    ' Set the worksheet
    Set ws = Sheet10
   
    ' Set the table
    Set tbl = ws.ListObjects("API_Races_Next_Starts")
   
    ' Set the specific column
    Set column = tbl.ListColumns(4)
   
    ' Get the current time
    currentTime = Now
   
        ' Loop through each cell in the column
           For Each cell In column.DataBodyRange
            ' Check if the time string is earlier than the current time
            If TimeValue(CDate(cell.Value)) < TimeValue(CDate(currentTime)) Then
                ' If earlier, move to the next cell
                'MsgBox "early, move on " & Format(cell.Value, "hh:mm")
                Set cell = cell.Offset(1, 0)
            Else
                'MsgBox "Cell time is after now " & Format(cell.Value, "hh:mm")
                Exit Sub
            End If
        Next cell
End Sub

can somebody please point me in the right direction. I suspect I am not declaring the cell variable correctly, but am not sure.

Thanks for your help.
 

Excel Facts

Create a chart in one keystroke
Select the data and press Alt+F1 to insert a default chart. You can change the default chart to any chart type
UPDATE:

I think I worked it out. At the start of the day, the table being checked does not have any values in column 4.

I have added the line:

On Error Resume Next and everything seems ok now.

Am I on the right track?

Thanks
 
Upvote 0
You should never just add On Error Resume Next without knowing why. ;) And you should always turn it off as soon as possible afterwards.

If your table is empty, then the databodyrange property can fail. I'd test for that like this:

VBA Code:
if tbl.listrows.count > 0 then
        ' Loop through each cell in the column
           For Each cell In column.DataBodyRange
            ' Check if the time string is earlier than the current time
            If TimeValue(CDate(cell.Value)) < TimeValue(CDate(currentTime)) Then
                ' If earlier, move to the next cell
                'MsgBox "early, move on " & Format(cell.Value, "hh:mm")
                Set cell = cell.Offset(1, 0)
            Else
                'MsgBox "Cell time is after now " & Format(cell.Value, "hh:mm")
                Exit Sub
            End If
        Next cell
   end if
 
Upvote 0
Solution
as always Rory. Thanks for your advice. I'll give it a go.
 
Upvote 0

Forum statistics

Threads
1,224,816
Messages
6,181,143
Members
453,021
Latest member
Justyna P

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