While loop to move to next row if while condition is met

mexaria

New Member
Joined
Apr 25, 2014
Messages
10
Hi Excel gurus,

I have put a code together (see below - working code with no copyright, fell free to use it) that analyzes an action plan (excel file with columns for actions, date and time of begin and ending of an action etc.) and creates outlook appointments based on the information on the lines of the action plan. The "Evento Criado" condition in the code was created to avoid creating duplicate appointments (if one was already created from a previous macro run).

FYI: Len(Cells(r, 8).Text) --> Column 8 receives planned start dates for an appointment to be created.

I want the code to keep analyzing the lines until the last instance of a planned appointment date on column 8. As it is now, the code stop running when it finds a line where cells(r,8) is blank. I want it to keep going until it finds the last cell in column 8 with a planned start date.

Thank you so much for your help!!
Kevin

VBA Code:
r = 7 ' first row with appointment data in the active worksheet
    Dim mysub, myStart, myEnd
    While Len(Cells(r, 8).Text) <> 0
        mysub = Cells(r, 4) & ", " & Cells(r, 5)
        myStart = DateValue(Cells(r, 8).Value) + Cells(r, 9).Value
        myEnd = DateValue(Cells(r, 8).Value) + Cells(r, 10).Value
        'DeleteTestAppointments mysub, myStart, myEnd
        Set olAppItem = olApp.CreateItem(olAppointmentItem) ' creates a new appointment
        With olAppItem
        If Cells(r, 14).Value <> "EventoCriado" Then
        ' set default appointment values
            .Location = Cells(r, 7)
            .Body = ""
            .ReminderSet = True
            .BusyStatus = olFree
            '.RequiredAttendees = "johndoe@microsoft.com"
            On Error Resume Next
            .Start = myStart
            .End = myEnd
            .Subject = Cells(r, 5)
            .Attachments.Add ("c:\temp\somefile.msg")
            .Location = Cells(r, 7).Value
            .Body = "A ação a ser realizada é " & Cells(r, 5) & ". Empresa " & Cells(r, 2) & ". Contrato iniciado em " & Cells(r, 1) & ". O serviço relacionado à esta ação é " & Cells(r, 4)
            .ReminderSet = True
            .BusyStatus = olBusy
            .Categories = "Orange Category" ' add this to be able to delete the testappointments
            On Error GoTo 0
            .Save ' saves the new appointment to the default folder
            Cells(r, 14) = "EventoCriado" 'Enter "Done" in Col M when appointment is created
        End If
        End With
        r = r + 1
    Wend
 

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.
try this simple modification which detects that last row an then sets up a loop from 7 to the last rtow:
VBA Code:
Sub test()
lastrow = Cells(Rows.Count, "H").End(xlUp).Row

'r = 7 ' first row with appointment data in the active worksheet
    Dim mysub, myStart, myEnd
'    While Len(Cells(r, 8).Text) <> 0
        For r = 7 To lastrow
        mysub = Cells(r, 4) & ", " & Cells(r, 5)
        myStart = DateValue(Cells(r, 8).Value) + Cells(r, 9).Value
        myEnd = DateValue(Cells(r, 8).Value) + Cells(r, 10).Value
        'DeleteTestAppointments mysub, myStart, myEnd
        Set olAppItem = olApp.CreateItem(olAppointmentItem) ' creates a new appointment
        With olAppItem
        If Cells(r, 14).Value <> "EventoCriado" Then
        ' set default appointment values
            .Location = Cells(r, 7)
            .Body = ""
            .ReminderSet = True
            .BusyStatus = olFree
            '.RequiredAttendees = "johndoe@microsoft.com"
            On Error Resume Next
            .Start = myStart
            .End = myEnd
            .Subject = Cells(r, 5)
            .Attachments.Add ("c:\temp\somefile.msg")
            .Location = Cells(r, 7).Value
            .Body = "A ação a ser realizada é " & Cells(r, 5) & ". Empresa " & Cells(r, 2) & ". Contrato iniciado em " & Cells(r, 1) & ". O serviço relacionado à esta ação é " & Cells(r, 4)
            .ReminderSet = True
            .BusyStatus = olBusy
            .Categories = "Orange Category" ' add this to be able to delete the testappointments
            On Error GoTo 0
            .Save ' saves the new appointment to the default folder
            Cells(r, 14) = "EventoCriado" 'Enter "Done" in Col M when appointment is created
        End If
        End With
 '       r = r + 1
 '   Wend
     Next r

End Sub
 
Upvote 0
try this simple modification which detects that last row an then sets up a loop from 7 to the last rtow:
VBA Code:
Sub test()
lastrow = Cells(Rows.Count, "H").End(xlUp).Row

'r = 7 ' first row with appointment data in the active worksheet
    Dim mysub, myStart, myEnd
'    While Len(Cells(r, 8).Text) <> 0
        For r = 7 To lastrow
        mysub = Cells(r, 4) & ", " & Cells(r, 5)
        myStart = DateValue(Cells(r, 8).Value) + Cells(r, 9).Value
        myEnd = DateValue(Cells(r, 8).Value) + Cells(r, 10).Value
        'DeleteTestAppointments mysub, myStart, myEnd
        Set olAppItem = olApp.CreateItem(olAppointmentItem) ' creates a new appointment
        With olAppItem
        If Cells(r, 14).Value <> "EventoCriado" Then
        ' set default appointment values
            .Location = Cells(r, 7)
            .Body = ""
            .ReminderSet = True
            .BusyStatus = olFree
            '.RequiredAttendees = "johndoe@microsoft.com"
            On Error Resume Next
            .Start = myStart
            .End = myEnd
            .Subject = Cells(r, 5)
            .Attachments.Add ("c:\temp\somefile.msg")
            .Location = Cells(r, 7).Value
            .Body = "A ação a ser realizada é " & Cells(r, 5) & ". Empresa " & Cells(r, 2) & ". Contrato iniciado em " & Cells(r, 1) & ". O serviço relacionado à esta ação é " & Cells(r, 4)
            .ReminderSet = True
            .BusyStatus = olBusy
            .Categories = "Orange Category" ' add this to be able to delete the testappointments
            On Error GoTo 0
            .Save ' saves the new appointment to the default folder
            Cells(r, 14) = "EventoCriado" 'Enter "Done" in Col M when appointment is created
        End If
        End With
'       r = r + 1
'   Wend
     Next r

End Sub

Thanks for the reply.

Your solution generates a type mismatch error '13' in
myStart = DateValue(Cells(r, 8).Value) + Cells(r, 9).Value

Only two data types exist in column 8 (from row 7): either a date or a blank
 
Upvote 0
try adding this check for zero length:
VBA Code:
Sub test()
lastrow = Cells(Rows.Count, "H").End(xlUp).Row

'r = 7 ' first row with appointment data in the active worksheet
    Dim mysub, myStart, myEnd
'    While Len(Cells(r, 8).Text) <> 0
     If Len(Cells(r, 8).Text) <> 0 Then

        For r = 7 To lastrow
        mysub = Cells(r, 4) & ", " & Cells(r, 5)
        myStart = DateValue(Cells(r, 8).Value) + Cells(r, 9).Value
        myEnd = DateValue(Cells(r, 8).Value) + Cells(r, 10).Value
        'DeleteTestAppointments mysub, myStart, myEnd
        Set olAppItem = olApp.CreateItem(olAppointmentItem) ' creates a new appointment
        With olAppItem
        If Cells(r, 14).Value <> "EventoCriado" Then
        ' set default appointment values
            .Location = Cells(r, 7)
            .Body = ""
            .ReminderSet = True
            .BusyStatus = olFree
            '.RequiredAttendees = "johndoe@microsoft.com"
            On Error Resume Next
            .Start = myStart
            .End = myEnd
            .Subject = Cells(r, 5)
            .Attachments.Add ("c:\temp\somefile.msg")
            .Location = Cells(r, 7).Value
            .Body = "A ação a ser realizada é " & Cells(r, 5) & ". Empresa " & Cells(r, 2) & ". Contrato iniciado em " & Cells(r, 1) & ". O serviço relacionado à esta ação é " & Cells(r, 4)
            .ReminderSet = True
            .BusyStatus = olBusy
            .Categories = "Orange Category" ' add this to be able to delete the testappointments
            On Error GoTo 0
            .Save ' saves the new appointment to the default folder
            Cells(r, 14) = "EventoCriado" 'Enter "Done" in Col M when appointment is created
        End If
        End With
 '       r = r + 1
 '   Wend
       End If
       
     Next r

End Sub
 
Upvote 0
Solution
Thanks so much! From your last answer I switched the position of two lines and it worked

Thanks again
 
Upvote 0

Forum statistics

Threads
1,224,822
Messages
6,181,165
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