Macro Autorun based on present Data

GW89

New Member
Joined
Aug 21, 2023
Messages
4
Office Version
  1. 365
Platform
  1. Windows
I currently have a code written to send and "Email_Notice" based on a value present condition for the last row of data entered. The data is transferred from a user form via a manual button macro. I am only wanting to execute this "Email_Notice" macro when the text value "Fail" is present in one of the multiple cells on the last row of data.

My current code will send the email when I manually start it as I do not have it configured to Loop yet but it will execute the "Email_Notice" sub whether or not "Fail" is within the data range. Can anyone tell me what I am doing wrong? (code below)
______________________________________________________________________________
Sub OOS_Finding()
'***File sends email when "Fail" is present in last row of recorded data. [Columns F-N]

On Error Resume Next
LastRow = Range ("A" & Rows.Count).End(xlUp).Row
Set Target = LastRow
If Target.Text = "Fail" Then Call Email_Notice

End Sub
_________________________________________________________________________________
Sub Email_Notice ()

'***Send Email to Identified Auditors When unit Fails Quality Check
Dim emailApplication As Object
Dim emailItem As Object
Set emailAppplication - CreateObject ("Outlook.Application")
Set emailItem - emailApplication.CreateItem(0)
emailItem.to - "user@email.com
emailItem.Subject = "Test"
emailItem.Body - "Quality Finding"
emailItem.Send
Set emailItem - Nothing
Set emailApplication - Nothing
End Sub

_______________________________________________________________________
 

Excel Facts

Quick Sum
Select a range of cells. The total appears in bottom right of Excel screen. Right-click total to add Max, Min, Count, Average.
My current code will send the email when I manually start it
Perhaps Autorun by calling the OOS_Finding sub at the end of the macro that tranfers the data to the sheet

I do not have it configured to Loop yet but it will execute the "Email_Notice" sub whether or not "Fail" is within the data range.
maybe something like this
VBA Code:
Sub OOS_Finding()
'***File sends email when "Fail" is present in last row of recorded data. [Columns F-N]

Dim LastRow As Long, rng As Range, cel As Range

With ActiveSheet
    LastRow = .Range("A" & .Rows.Count).End(xlUp).Row
    Set rng = .Cells(LastRow, "F").Resize(, 9)
End With
    
For Each cel In rng
    If cel.Value = "Fail" Then
        Call Email_Notice
        Exit For
    End If
Next cel

End Sub
 
Upvote 0
Perhaps Autorun by calling the OOS_Finding sub at the end of the macro that tranfers the data to the sheet


maybe something like this
VBA Code:
Sub OOS_Finding()
'***File sends email when "Fail" is present in last row of recorded data. [Columns F-N]

Dim LastRow As Long, rng As Range, cel As Range

With ActiveSheet
    LastRow = .Range("A" & .Rows.Count).End(xlUp).Row
    Set rng = .Cells(LastRow, "F").Resize(, 9)
End With
   
For Each cel In rng
    If cel.Value = "Fail" Then
        Call Email_Notice
        Exit For
    End If
Next cel

End Sub
NoSparks,

I tried this but it didn't identify the "Fail" value on the line. While you were working on this I was able to apply an IF statement inline with my raw data to generate a CountValue for "Fail" appearances. I then created the macro below to pull that value and process the Email_Notice macro from that. I was able to add the Call OOS_Finding to the end of my initial Macro for the autorun though so much thanks there as you save me some trial and error time.

Sub OOS_Finding()
'Looks for Integer Value created by imbedded IF statement which COUNTS "Fail" occurences [=COUNTIF((F2:N2),"Fail")]

LastRow = Sheets("Database").Range("A" & Rows.Count).End(xlUp).Row

Target = Range("S" & LastRow).Value

If Target > 0 Then Call Email_Notice

End Sub
 
Upvote 0

Forum statistics

Threads
1,225,739
Messages
6,186,738
Members
453,369
Latest member
juliewar

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