Good day all , I am trying to find each cell value in column A of worksheet "OFSHC" in worksheet "User Assessments" and if value found then return "true" in column V of the corresponding cell in worksheet "OFSHC" else return "false. I have the code below , however; I am working with +90000 rows in worksheet "OFSHC" and +900000 rows in sheet "User Assessments" , which makes the code to run over 6 hours. any idea on optimizing the code to run for a shorter period of time?
Code:
Sub findUsername_OFSHC_User_Assessments()
Worksheets("OFSHC").Activate
    Dim FindString As String
    Dim Rng As Range
    For Each Cell In Range("A2:A35000")
        FindString = Cell.Value
        
        If Trim(FindString) <> "" Then
            'The 2nd worksheet is assumed to be User Assessments. Change this if it is not the case
            With Sheets("User Assessments").Range("D1:D900000")
                Set Rng = .Find(What:=FindString, _
                                After:=.Cells(.Cells.Count), _
                                LookIn:=xlValues, _
                                LookAt:=xlWhole, _
                                SearchOrder:=xlByRows, _
                                SearchDirection:=xlNext, _
                                MatchCase:=False)
                If Not Rng Is Nothing Then
                    Application.GoTo Rng, True
                    'In Sheet 2: This line shifts 5 cells to the right and gets the country value
                    'Found = ActiveCell.Offset(0, 5).Value
                    'In Sheet 1: Found value is pasted into the cell 3 cells to the right of the cell containing the Workday usernme
                    Cell.Offset(0, 22).Value = "True"
                Else
                    Cell.Offset(0, 22).Value = "False"
                End If
            End With
        End If
    Next
End Sub
 
     
    