How to execute VBA every 10 minutes?

lojanica

New Member
Joined
Feb 22, 2024
Messages
39
Office Version
  1. 365
Platform
  1. Windows
My VBA code is in Module 1 and instead of exciting it manually and on opening of document only I would like to have it execute every 10 min while the document is open. Also, a document is opened by several people at the same time.
Can anyone help with this?

The code below is the one I am looking to execute every 10 min. This is currently being done by opening the document and manually executing it.

VBA Code:
Sub FilterUserTab()

 Dim mainwb As Workbook
    Dim usernameSheetName As String
    Dim targetSheet As Worksheet

' Below code is to update new and closed jobs
        
     Set mainwb = ActiveWorkbook
    Set flowDataSheet = mainwb.Sheets("FlowData")
    Set registerSheet = mainwb.Sheets("AMSI-R-102 Job Request Register")
    
    ' Check if the worksheet has autofilter applied
    registerSheet.Activate
    If registerSheet.AutoFilterMode Then
        registerSheet.AutoFilter.ShowAllData
    End If
    
     ' Set references to the ListObject and columns in FlowData sheet
    flowDataSheet.Activate
    Set table1 = flowDataSheet.ListObjects("Table1")
    Set indexColumn = table1.ListColumns("index").DataBodyRange
    Set jobNoColumn = table1.ListColumns("Job No.:").DataBodyRange
    
    ' Loop through each row in the index column of Table1
    
    For i = 1 To indexColumn.Rows.Count
        Set flowDataRow = indexColumn.Cells(i)
        ' Check if the cell in the index column is empty or contains a formula that returns an empty value
        If IsEmpty(flowDataRow.Value) Or flowDataRow.Value = "" Then
            ' Find the corresponding Job No. value in the same row of the table1 in flowdata sheet
            jobNo = jobNoColumn.Cells(flowDataRow.Row - indexColumn.Row + 1).Value
            ' Find the last used row in column B of the register sheet
            lastRow = registerSheet.Cells(registerSheet.Rows.Count, "B").End(xlUp).Row
            ' Copy the Job No. value to the last row + 1 in column B of the register sheet
            'registerSheet.Cells(lastRow + 1, "B").Value = jobNo
            registerSheet.Cells(lastRow + 1, "B").Formula = "=HYPERLINK('FlowData'!P" & i + 1 & ",'FlowData'!B" & i + 1 & ")"
        End If
    Next i
' Update new and closed jobe done next step is Filter user tab
       
    ThisWorkbook.Sheets("AMSI-R-102 Job Request Register").Range("B6").Value = Environ("USERNAME")
    Set mainwb = ActiveWorkbook
    usernameSheetName = mainwb.Sheets("AMSI-R-102 Job Request Register").Range("B6").Value
        
    On Error Resume Next
    Set targetSheet = mainwb.Sheets(usernameSheetName)
    On Error GoTo 0
    
    If Not targetSheet Is Nothing Then
        targetSheet.Activate
    Else
        mainwb.Sheets("AMSI-R-102 Job Request Register").Activate
        Exit Sub
    End If

    If (ActiveSheet.AutoFilterMode And ActiveSheet.FilterMode) Or ActiveSheet.FilterMode Then
        ActiveSheet.ShowAllData
    End If

    Range("A8:N8").AutoFilter Field:=13, Criteria1:=Range("B6")
    Range("A8:N8").AutoFilter Field:=12, Criteria1:="In progress"
    
    lastRow = Cells(Rows.Count, 2).End(xlUp).Row
    Range("A8:N" & lastRow).Sort Key1:=Range("F8:F" & lastRow), Order1:=xlAscending, Header:=xlNo

End Sub
 
I have updated a spreadsheet to make it easier for troubleshooting, i hope that helps
I located a few typos in your macro code. Taken the liberty to copy all of your code and insert the proper commands where they needed to be.
\
Copy / paste the following into a COPY of your workbook (having removed all of the code from the copy PRIOR to pasting the following code).
Let me know how it runs.

Code:
Option Explicit

Sub FilterAll()

Dim mainwb As Workbook
    Dim flowDataSheet As Worksheet
    Dim registerSheet As Worksheet
    Dim lastRow As Long
    Dim table1 As ListObject
    Dim jobNoColumn As Range
    Dim indexColumn As Range
    Dim flowDataRow As Range
    Dim jobNo As Variant
    Dim i As Long

    ' Set references to the main workbook and relevant sheets
    Set mainwb = ActiveWorkbook
    Set flowDataSheet = mainwb.Sheets("FlowData")
    Set registerSheet = mainwb.Sheets("AMSI-R-102 Job Request Register")
   
    ' Check if the worksheet has autofilter applied
    registerSheet.Activate
    If registerSheet.AutoFilterMode Then
        registerSheet.AutoFilter.ShowAllData
    End If
   
    ' Set references to the ListObject and columns in FlowData sheet
    flowDataSheet.Activate
    Set table1 = flowDataSheet.ListObjects("Table1")
    Set indexColumn = table1.ListColumns("index").DataBodyRange
    Set jobNoColumn = table1.ListColumns("Job No.:").DataBodyRange
   
    ' Loop through each row in the index column of Table1
   
    For i = 1 To indexColumn.Rows.Count
        Set flowDataRow = indexColumn.Cells(i)
        ' Check if the cell in the index column is empty or contains a formula that returns an empty value
        If IsEmpty(flowDataRow.Value) Or flowDataRow.Value = "" Then
            ' Find the corresponding Job No. value in the same row of the table1 in flowdata sheet
            jobNo = jobNoColumn.Cells(flowDataRow.Row - indexColumn.Row + 1).Value
            ' Find the last used row in column B of the register sheet
            lastRow = registerSheet.Cells(registerSheet.Rows.Count, "B").End(xlUp).Row
            ' Copy the Job No. value to the last row + 1 in column B of the register sheet
            'registerSheet.Cells(lastRow + 1, "B").Value = jobNo
            registerSheet.Cells(lastRow + 1, "B").Formula = "=HYPERLINK('FlowData'!P" & i + 1 & ",'FlowData'!B" & i + 1 & ")"
        End If
    Next i
   
    registerSheet.Activate
   
'-----Above code is to activate data flow and below is basic filtering----

Set mainwb = ActiveWorkbook

mainwb.Sheets("AMSI-R-102 Job Request Register").Activate
mainwb.Sheets("AMSI-R-102 Job Request Register").Range("A8").Select
If (ActiveSheet.AutoFilterMode And ActiveSheet.FilterMode) Or ActiveSheet.FilterMode Then
  ActiveSheet.ShowAllData
End If
 Cells(Rows.Count, 2).End(xlUp).Offset(1, 0).Select
 
 Range("B6").Value = Environ("USERNAME")


 
   
   
End Sub



Sub ScheduleclrCol()

Dim TimeToRun

    TimeToRun = Now + TimeValue("00:00:10")     '<----- adjust time to fire here  HH:MM:SS
   
    '##############################################################################################################################
   
    Application.OnTime TimeToRun, "FilterUserTab"   '<----------------------------------------- I changed the macro reference here.
   
    '##############################################################################################################################
   
End Sub


Sub FilterUserTab()

 Dim mainwb As Workbook
    Dim usernameSheetName As String
    Dim targetSheet As Worksheet

' Below code is to update new and closed jobs
       
     Set mainwb = ActiveWorkbook
    Set flowDataSheet = mainwb.Sheets("FlowData")
    Set registerSheet = mainwb.Sheets("AMSI-R-102 Job Request Register")
   
    ' Check if the worksheet has autofilter applied
    registerSheet.Activate
    If registerSheet.AutoFilterMode Then
        registerSheet.AutoFilter.ShowAllData
    End If
   
     ' Set references to the ListObject and columns in FlowData sheet
    flowDataSheet.Activate
    Set table1 = flowDataSheet.ListObjects("Table1")
    Set indexColumn = table1.ListColumns("index").DataBodyRange
    Set jobNoColumn = table1.ListColumns("Job No.:").DataBodyRange
   
    ' Loop through each row in the index column of Table1
   
    For i = 1 To indexColumn.Rows.Count
        Set flowDataRow = indexColumn.Cells(i)
        ' Check if the cell in the index column is empty or contains a formula that returns an empty value
        If IsEmpty(flowDataRow.Value) Or flowDataRow.Value = "" Then
            ' Find the corresponding Job No. value in the same row of the table1 in flowdata sheet
            jobNo = jobNoColumn.Cells(flowDataRow.Row - indexColumn.Row + 1).Value
            ' Find the last used row in column B of the register sheet
            lastRow = registerSheet.Cells(registerSheet.Rows.Count, "B").End(xlUp).Row
            ' Copy the Job No. value to the last row + 1 in column B of the register sheet
            'registerSheet.Cells(lastRow + 1, "B").Value = jobNo
            registerSheet.Cells(lastRow + 1, "B").Formula = "=HYPERLINK('FlowData'!P" & i + 1 & ",'FlowData'!B" & i + 1 & ")"
        End If
    Next i
' Update new and closed jobe done next step is Filter user tab
     
    ThisWorkbook.Sheets("AMSI-R-102 Job Request Register").Range("B6").Value = Environ("USERNAME")
    Set mainwb = ActiveWorkbook
    usernameSheetName = mainwb.Sheets("AMSI-R-102 Job Request Register").Range("B6").Value
       
    On Error Resume Next
    Set targetSheet = mainwb.Sheets(usernameSheetName)
    On Error GoTo 0
   
    If Not targetSheet Is Nothing Then
        targetSheet.Activate
    Else
        mainwb.Sheets("AMSI-R-102 Job Request Register").Activate
        Exit Sub
    End If

    If (ActiveSheet.AutoFilterMode And ActiveSheet.FilterMode) Or ActiveSheet.FilterMode Then
        ActiveSheet.ShowAllData
    End If

    Range("A8:N8").AutoFilter Field:=13, Criteria1:=Range("B6")
    Range("A8:N8").AutoFilter Field:=12, Criteria1:="In progress"
   
    lastRow = Cells(Rows.Count, 2).End(xlUp).Row
    Range("A8:N" & lastRow).Sort Key1:=Range("F8:F" & lastRow), Order1:=xlAscending, Header:=xlNo
   
    '##############################################################################################################################
   
    ScheduleclrCol          '<----------------------------- I changed the macro reference here.
   
    '##############################################################################################################################


End Sub

Sub flowdata()
    Dim mainwb As Workbook
    Dim flowDataSheet As Worksheet
    Dim registerSheet As Worksheet
    Dim lastRow As Long
    Dim table1 As ListObject
    Dim jobNoColumn As Range
    Dim indexColumn As Range
    Dim flowDataRow As Range
    Dim jobNo As Variant
    Dim i As Long

    ' Set references to the main workbook and relevant sheets
    Set mainwb = ActiveWorkbook
    Set flowDataSheet = mainwb.Sheets("FlowData")
    Set registerSheet = mainwb.Sheets("AMSI-R-102 Job Request Register")
   
    ' Check if the worksheet has autofilter applied
    registerSheet.Activate
    If registerSheet.AutoFilterMode Then
        registerSheet.AutoFilter.ShowAllData
    End If
   
    ' Set references to the ListObject and columns in FlowData sheet
    flowDataSheet.Activate
    Set table1 = flowDataSheet.ListObjects("Table1")
    Set indexColumn = table1.ListColumns("index").DataBodyRange
    Set jobNoColumn = table1.ListColumns("Job No.:").DataBodyRange
   
    ' Loop through each row in the index column of Table1
   
    For i = 1 To indexColumn.Rows.Count
        Set flowDataRow = indexColumn.Cells(i)
        ' Check if the cell in the index column is empty or contains a formula that returns an empty value
        If IsEmpty(flowDataRow.Value) Or flowDataRow.Value = "" Then
            ' Find the corresponding Job No. value in the same row of the table1 in flowdata sheet
            jobNo = jobNoColumn.Cells(flowDataRow.Row - indexColumn.Row + 1).Value
            ' Find the last used row in column B of the register sheet
            lastRow = registerSheet.Cells(registerSheet.Rows.Count, "B").End(xlUp).Row
            ' Copy the Job No. value to the last row + 1 in column B of the register sheet
            'registerSheet.Cells(lastRow + 1, "B").Value = jobNo
            registerSheet.Cells(lastRow + 1, "B").Formula = "=HYPERLINK('FlowData'!P" & i + 1 & ",'FlowData'!B" & i + 1 & ")"
        End If
    Next i
   
    registerSheet.Activate

End Sub



' The remaining code is to set a timer for document ideal time,
' Once the document is ideal for the bellow set time, the document will save and close
' Three private subs in "ThisWorkbook" are controlling the below code

'Option Explicit

'Dim CloseTime As Date
'Sub TimeSetting()
    'CloseTime = Now + TimeValue("00:00:20")
    'On Error Resume Next
    'Application.OnTime EarliestTime:=CloseTime, _
      'Procedure:="SavedAndClose", Schedule:=True
'End Sub
'Sub TimeStop()
    'On Error Resume Next
    'Application.OnTime EarliestTime:=CloseTime, _
      'Procedure:="SavedAndClose", Schedule:=False
 'End Sub
'Sub SavedAndClose()
    'Application.DisplayAlerts = False
    'ActiveWorkbook.Close Savechanges:=True
    'Application.DisplayAlerts = True
'End Sub

Sub FilterE5()

    Dim mainwb As Workbook
    Dim targetSheet As Worksheet
   
     ' Set references to the main workbook and relevant sheets
    'Set mainwb = ActiveWorkbook
    'Set registerSheet = mainwb.Sheets("AMSI-R-102 Job Request Register")
 
    If (ActiveSheet.AutoFilterMode And ActiveSheet.FilterMode) Or ActiveSheet.FilterMode Then
        ActiveSheet.ShowAllData
    End If

    Range("A8:NN8").AutoFilter Field:=17, Criteria1:=Range("E5")
    Range("A8:NN8").AutoFilter Field:=19, Criteria1:="In progress"
   
 

End Sub
Thank you for looking to solve this issue it is much appreciated!

when "Option Explicit" is introduced in code I always get an error from the attached photo.
once "Option Explicit' is removed, the code is compiling with no issues and unfortunately, it is the same as before
If I press run it will execute in 10 seconds but will not do it every 10 seconds

It would be much easier I guess if I could send an Excel document
 

Attachments

  • Screenshot 2024-12-18 081334.jpg
    Screenshot 2024-12-18 081334.jpg
    119 KB · Views: 5
Upvote 0

Excel Facts

What is the fastest way to copy a formula?
If A2:A50000 contain data. Enter a formula in B2. Select B2. Double-click the Fill Handle and Excel will shoot the formula down to B50000.
Find the "FilterUserTab" macro ...

Then at the beginning of the macro, insert these lines of code. NOTE: I included the macro name AND a few lines of code already existing in your macro.
ONLY ADD THE NEW LINES OF CODE TO YOUR MACRO, IN THE LOCATION INDICATED BY THE FOLLOWING :

VBA Code:
Sub FilterUserTab()                     '<---- don't include this line of code !!!


'#######################################   ONLY ADD THE LINES BETWEEN THE ############

 Dim mainwb As Workbook
    Dim usernameSheetName As String
    Dim targetSheet As Worksheet
    Dim flowDataSheet As Worksheet
    Dim registerSheet As Worksheet
    Dim table1
    Dim indexColumn
    Dim jobNoColumn
    Dim i As Long
    Dim flowDataRow
    Dim jobNo As Long
    Dim lastRow As Variant
    
'#######################################   ONLY ADD THE LINES BETWEEN THE ############
    
    
    
''<---- don't include the following lines of code !!!
    
' Below code is to update new and closed jobs
        
     Set mainwb = ActiveWorkbook
    Set flowDataSheet = mainwb.Sheets("FlowData")
    Set registerSheet = mainwb.Sheets("AMSI-R-102 Job Request Register")
 
Upvote 0
Find the "FilterUserTab" macro ...

Then at the beginning of the macro, insert these lines of code. NOTE: I included the macro name AND a few lines of code already existing in your macro.
ONLY ADD THE NEW LINES OF CODE TO YOUR MACRO, IN THE LOCATION INDICATED BY THE FOLLOWING :

VBA Code:
Sub FilterUserTab()                     '<---- don't include this line of code !!!


'#######################################   ONLY ADD THE LINES BETWEEN THE ############

 Dim mainwb As Workbook
    Dim usernameSheetName As String
    Dim targetSheet As Worksheet
    Dim flowDataSheet As Worksheet
    Dim registerSheet As Worksheet
    Dim table1
    Dim indexColumn
    Dim jobNoColumn
    Dim i As Long
    Dim flowDataRow
    Dim jobNo As Long
    Dim lastRow As Variant
   
'#######################################   ONLY ADD THE LINES BETWEEN THE ############
   
   
   
''<---- don't include the following lines of code !!!
   
' Below code is to update new and closed jobs
       
     Set mainwb = ActiveWorkbook
    Set flowDataSheet = mainwb.Sheets("FlowData")
    Set registerSheet = mainwb.Sheets("AMSI-R-102 Job Request Register")
No more errors, however it still only works when i run it not every 10 sec

VBA Code:
Option Explicit
Sub FilterAll()

Dim mainwb As Workbook
    Dim flowDataSheet As Worksheet
    Dim registerSheet As Worksheet
    Dim lastRow As Long
    Dim table1 As ListObject
    Dim jobNoColumn As Range
    Dim indexColumn As Range
    Dim flowDataRow As Range
    Dim jobNo As Variant
    Dim i As Long

    ' Set references to the main workbook and relevant sheets
    Set mainwb = ActiveWorkbook
    Set flowDataSheet = mainwb.Sheets("FlowData")
    Set registerSheet = mainwb.Sheets("AMSI-R-102 Job Request Register")
    
    ' Check if the worksheet has autofilter applied
    registerSheet.Activate
    If registerSheet.AutoFilterMode Then
        registerSheet.AutoFilter.ShowAllData
    End If
    
    ' Set references to the ListObject and columns in FlowData sheet
    flowDataSheet.Activate
    Set table1 = flowDataSheet.ListObjects("Table1")
    Set indexColumn = table1.ListColumns("index").DataBodyRange
    Set jobNoColumn = table1.ListColumns("Job No.:").DataBodyRange
    
    ' Loop through each row in the index column of Table1
    
    For i = 1 To indexColumn.Rows.Count
        Set flowDataRow = indexColumn.Cells(i)
        ' Check if the cell in the index column is empty or contains a formula that returns an empty value
        If IsEmpty(flowDataRow.Value) Or flowDataRow.Value = "" Then
            ' Find the corresponding Job No. value in the same row of the table1 in flowdata sheet
            jobNo = jobNoColumn.Cells(flowDataRow.Row - indexColumn.Row + 1).Value
            ' Find the last used row in column B of the register sheet
            lastRow = registerSheet.Cells(registerSheet.Rows.Count, "B").End(xlUp).Row
            ' Copy the Job No. value to the last row + 1 in column B of the register sheet
            'registerSheet.Cells(lastRow + 1, "B").Value = jobNo
            registerSheet.Cells(lastRow + 1, "B").Formula = "=HYPERLINK('FlowData'!P" & i + 1 & ",'FlowData'!B" & i + 1 & ")"
        End If
    Next i
    
    registerSheet.Activate
    
'-----Above code is to activate data flow and below is basic filtering----

Set mainwb = ActiveWorkbook

mainwb.Sheets("AMSI-R-102 Job Request Register").Activate
mainwb.Sheets("AMSI-R-102 Job Request Register").Range("A8").Select
If (ActiveSheet.AutoFilterMode And ActiveSheet.FilterMode) Or ActiveSheet.FilterMode Then
  ActiveSheet.ShowAllData
End If
 Cells(Rows.Count, 2).End(xlUp).Offset(1, 0).Select
 
 Range("B6").Value = Environ("USERNAME")

    
End Sub

Sub ScheduleclrCol()

Dim TimeToRun

    TimeToRun = Now + TimeValue("00:00:10")     '<----- adjust time to fire here  HH:MM:SS
    
    '##############################################################################################################################
    
    Application.OnTime TimeToRun, "FilterUserTab"   '<----------------------------------------- I changed the macro reference here.
    
    '##############################################################################################################################
    
End Sub

Sub FilterUserTab()

Dim mainwb As Workbook
    Dim usernameSheetName As String
    Dim targetSheet As Worksheet
    Dim flowDataSheet As Worksheet
    Dim registerSheet As Worksheet
    Dim table1
    Dim indexColumn
    Dim jobNoColumn
    Dim i As Long
    Dim flowDataRow
    Dim jobNo As Long
    Dim lastRow As Variant

' Below code is to update new and closed jobs
        
     Set mainwb = ActiveWorkbook
    Set flowDataSheet = mainwb.Sheets("FlowData")
    Set registerSheet = mainwb.Sheets("AMSI-R-102 Job Request Register")
    
    ' Check if the worksheet has autofilter applied
    registerSheet.Activate
    If registerSheet.AutoFilterMode Then
        registerSheet.AutoFilter.ShowAllData
    End If
    
     ' Set references to the ListObject and columns in FlowData sheet
    flowDataSheet.Activate
    Set table1 = flowDataSheet.ListObjects("Table1")
    Set indexColumn = table1.ListColumns("index").DataBodyRange
    Set jobNoColumn = table1.ListColumns("Job No.:").DataBodyRange
    
    ' Loop through each row in the index column of Table1
    
    For i = 1 To indexColumn.Rows.Count
        Set flowDataRow = indexColumn.Cells(i)
        ' Check if the cell in the index column is empty or contains a formula that returns an empty value
        If IsEmpty(flowDataRow.Value) Or flowDataRow.Value = "" Then
            ' Find the corresponding Job No. value in the same row of the table1 in flowdata sheet
            jobNo = jobNoColumn.Cells(flowDataRow.Row - indexColumn.Row + 1).Value
            ' Find the last used row in column B of the register sheet
            lastRow = registerSheet.Cells(registerSheet.Rows.Count, "B").End(xlUp).Row
            ' Copy the Job No. value to the last row + 1 in column B of the register sheet
            'registerSheet.Cells(lastRow + 1, "B").Value = jobNo
            registerSheet.Cells(lastRow + 1, "B").Formula = "=HYPERLINK('FlowData'!P" & i + 1 & ",'FlowData'!B" & i + 1 & ")"
        End If
    Next i
' Update new and closed jobe done next step is Filter user tab
      
    ThisWorkbook.Sheets("AMSI-R-102 Job Request Register").Range("B6").Value = Environ("USERNAME")
    Set mainwb = ActiveWorkbook
    usernameSheetName = mainwb.Sheets("AMSI-R-102 Job Request Register").Range("B6").Value
        
    On Error Resume Next
    Set targetSheet = mainwb.Sheets(usernameSheetName)
    On Error GoTo 0
    
    If Not targetSheet Is Nothing Then
        targetSheet.Activate
    Else
        mainwb.Sheets("AMSI-R-102 Job Request Register").Activate
        Exit Sub
    End If

    If (ActiveSheet.AutoFilterMode And ActiveSheet.FilterMode) Or ActiveSheet.FilterMode Then
        ActiveSheet.ShowAllData
    End If

    Range("A8:N8").AutoFilter Field:=13, Criteria1:=Range("B6")
    Range("A8:N8").AutoFilter Field:=12, Criteria1:="In progress"
    
    lastRow = Cells(Rows.Count, 2).End(xlUp).Row
    Range("A8:N" & lastRow).Sort Key1:=Range("F8:F" & lastRow), Order1:=xlAscending, Header:=xlNo
    
    
   '##############################################################################################################################
    
    ScheduleclrCol          '<----------------------------- I changed the macro reference here.
    
    '##############################################################################################################################

End Sub

Sub flowdata()
    Dim mainwb As Workbook
    Dim flowDataSheet As Worksheet
    Dim registerSheet As Worksheet
    Dim lastRow As Long
    Dim table1 As ListObject
    Dim jobNoColumn As Range
    Dim indexColumn As Range
    Dim flowDataRow As Range
    Dim jobNo As Variant
    Dim i As Long

    ' Set references to the main workbook and relevant sheets
    Set mainwb = ActiveWorkbook
    Set flowDataSheet = mainwb.Sheets("FlowData")
    Set registerSheet = mainwb.Sheets("AMSI-R-102 Job Request Register")
    
    ' Check if the worksheet has autofilter applied
    registerSheet.Activate
    If registerSheet.AutoFilterMode Then
        registerSheet.AutoFilter.ShowAllData
    End If
    
    ' Set references to the ListObject and columns in FlowData sheet
    flowDataSheet.Activate
    Set table1 = flowDataSheet.ListObjects("Table1")
    Set indexColumn = table1.ListColumns("index").DataBodyRange
    Set jobNoColumn = table1.ListColumns("Job No.:").DataBodyRange
    
    ' Loop through each row in the index column of Table1
    
    For i = 1 To indexColumn.Rows.Count
        Set flowDataRow = indexColumn.Cells(i)
        ' Check if the cell in the index column is empty or contains a formula that returns an empty value
        If IsEmpty(flowDataRow.Value) Or flowDataRow.Value = "" Then
            ' Find the corresponding Job No. value in the same row of the table1 in flowdata sheet
            jobNo = jobNoColumn.Cells(flowDataRow.Row - indexColumn.Row + 1).Value
            ' Find the last used row in column B of the register sheet
            lastRow = registerSheet.Cells(registerSheet.Rows.Count, "B").End(xlUp).Row
            ' Copy the Job No. value to the last row + 1 in column B of the register sheet
            'registerSheet.Cells(lastRow + 1, "B").Value = jobNo
            registerSheet.Cells(lastRow + 1, "B").Formula = "=HYPERLINK('FlowData'!P" & i + 1 & ",'FlowData'!B" & i + 1 & ")"
        End If
    Next i
    
    registerSheet.Activate

End Sub



' The remaining code is to set a timer for document ideal time,
' Once the document is ideal for the bellow set time, the document will save and close
' Three private subs in "ThisWorkbook" are controlling the below code

'Option Explicit

'Dim CloseTime As Date
'Sub TimeSetting()
    'CloseTime = Now + TimeValue("00:00:20")
    'On Error Resume Next
    'Application.OnTime EarliestTime:=CloseTime, _
      'Procedure:="SavedAndClose", Schedule:=True
'End Sub
'Sub TimeStop()
    'On Error Resume Next
    'Application.OnTime EarliestTime:=CloseTime, _
      'Procedure:="SavedAndClose", Schedule:=False
 'End Sub
'Sub SavedAndClose()
    'Application.DisplayAlerts = False
    'ActiveWorkbook.Close Savechanges:=True
    'Application.DisplayAlerts = True
'End Sub

Sub FilterE5()

    Dim mainwb As Workbook
    Dim targetSheet As Worksheet
    
     ' Set references to the main workbook and relevant sheets
    'Set mainwb = ActiveWorkbook
    'Set registerSheet = mainwb.Sheets("AMSI-R-102 Job Request Register")
   
    If (ActiveSheet.AutoFilterMode And ActiveSheet.FilterMode) Or ActiveSheet.FilterMode Then
        ActiveSheet.ShowAllData
    End If

    Range("A8:NN8").AutoFilter Field:=17, Criteria1:=Range("E5")
    Range("A8:NN8").AutoFilter Field:=19, Criteria1:="In progress"
    
  

End Sub
 
Upvote 0
Paste the following code into a NEW WORKBOOK regular module. Connect a command button to the macro "FilterUserTab "
then run it. See if the timer runs every 10 seconds as designed.

VBA Code:
Sub ScheduleclrCol()

Dim TimeToRun

    TimeToRun = Now + TimeValue("00:00:10")     '<----- adjust time to fire here  HH:MM:SS
    
    '##############################################################################################################################
    
    Application.OnTime TimeToRun, "FilterUserTab"   '<----------------------------------------- I changed the macro reference here.
    
    '##############################################################################################################################
    
End Sub


Sub FilterUserTab()                     '<---- don't include this line of code !!!


Range("A1").Value = Range("A1").Value + 1
    
    '##############################################################################################################################
    
    ScheduleclrCol          '<----------------------------- I changed the macro reference here.
    
    '##############################################################################################################################


End Sub
 
Upvote 0
If it runs as expected, the number in Cell A1 should increment by one, every 10 seconds.
 
Upvote 0
If it runs as expected, the number in Cell A1 should increment by one, every 10 seconds.
okay I have pasted the following code, please see my extra comments in red
this has been added to the new blank document and workers as expected when i run keep adding numbers, however, if i reopen the document and enable macro it does nothing
VBA Code:
Sub ScheduleclrCol()

Dim TimeToRun

    TimeToRun = Now + TimeValue("00:00:10")     '<----- adjust time to fire here  HH:MM:SS
    
    '##############################################################################################################################
    
    Application.OnTime TimeToRun, "FilterUserTab"   '<----------------------------------------- I changed the macro reference here.
    
    '##############################################################################################################################
    
End Sub


Sub FilterUserTab()                     '<---- don't include this line of code !!![COLOR=rgb(184, 49, 47)]I have kept this in code is that okay [/COLOR]


Range("A1").Value = Range("A1").Value + 1
    
    '##############################################################################################################################
    
    ScheduleclrCol          '<----------------------------- I changed the macro reference here.
    
    '##############################################################################################################################


End Sub
 
Upvote 0
Enabled macros should be on at all times. It is not something you do when you open the workbook. Enable macros then save the workbook. The macros will be enabled automatically
the next time you open the workbook and every time after that.

Just opening the workbook will not make the macro run. You still have to click the button.
 
Upvote 0
<span>I have kept this in code is that okay</span>
Yes that is okay and required. I overlooked having that comment in the code I gave you. Sorry.
 
Upvote 0
Could you tell me where you are located ?
 
Upvote 0
Could you tell me where you are located ?
I meant Enable content as per the photo attached
I am in Western Australia
 

Attachments

  • Screenshot 2024-12-18 110337.jpg
    Screenshot 2024-12-18 110337.jpg
    42.1 KB · Views: 5
Upvote 0

Forum statistics

Threads
1,225,619
Messages
6,186,045
Members
453,335
Latest member
sfd039

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