Loop in macro calculating twice instead of once.

MMasiarek

New Member
Joined
Mar 2, 2021
Messages
20
Office Version
  1. 365
  2. 2019
Platform
  1. Windows
Hello :)

I have a problem with my macro that should find me a lowest result in the column and add 1 to it.
Macro is started from my outlook and should work on unread emails in my Inbox.
Result of Macro should be name of subfolder where my email should go.

In Outlook I have code:
VBA Code:
Public Sub Rozdzielnik()

    Dim olNs As Outlook.NameSpace
    Dim Inbox As Outlook.MAPIFolder
    Dim Items As Outlook.Items
    Dim Item As Object
    Dim Atmt As Attachment
    Dim Filter As String
    Dim FilePath As String
    Dim AtmtName As String
    Dim i As Long
    Dim Subject As String
    
    ' Set up Outlook objects
    Set olNs = Application.GetNamespace("MAPI")
    Set Inbox = olNs.Folders("Poland e-learning").Folders("Inbox")
    
    ' Set up Excel object
    Dim xlApp As Excel.Application
    Dim xlWB As Excel.Workbook
    Dim xlWS As Excel.Worksheet
    
    ' Open Excel workbook
    Set xlApp = New Excel.Application
    Set xlWB = xlApp.Workbooks.Open("C:\Users\mmasiarek\Desktop\Rozdzielnik.xlsm", UpdateLinks:=False)
    Set xlWS = xlWB.Worksheets("Sheet1")
    
    ' Loop through each unread email in Inbox
    Filter = "[Unread] = True"
    Set Items = Inbox.Items.Restrict(Filter)
    
    For i = Items.Count To 1 Step -1
        Set Item = Items.Item(i)
        
        ' Call Excel macro to process email
        Subject = Item.Subject
        xlWB.Application.Run ("Rozdzielnik.xlsm!Sheet1.Rozdziel(" & Left(Subject, 3) & ")")
       ' xlApp.Run "Rozdziel", Left(Subject, 3)
        
        ' Get folder to move email to
        Dim folderName As String
        folderName = xlWS.Range("J6").Value
        Dim destFolder As Outlook.MAPIFolder
        Set destFolder = Inbox.Folders(folderName)
        
        ' Move email to folder
        Item.Move destFolder
    Next
    
    ' Close Excel workbook
    xlWB.Close SaveChanges:=True
    xlApp.Quit
    
    Set xlWS = Nothing
    Set xlWB = Nothing
    Set xlApp = Nothing
    
    ' Clean up Outlook objects
    Set Inbox = Nothing
    Set Items = Nothing
    Set olNs = Nothing
    
End Sub

In Excel I have macro:
VBA Code:
Function Rozdziel(LoB As String) As String
    Dim result As String
    
    If LoB = 422 Or LoB = 402 Then
        result = AH()
        Range("J6").Value = result
    ElseIf LoB = 403 Then
        result = CAS()
        Range("J6").Value = result
    ElseIf LoB = 408 Or LoB = 423 Or LoB = 413 Or LoB = 430 Then
        result = FIN_EIL_Marine()
        Range("J6").Value = result
    ElseIf LoB = 406 Or LoB = 416 Then
        result = PROP()
        Range("J6").Value = result
    End If
    
End Function

Function AH() As String
    Dim rng As Range
    Dim sumVal As Double
    Dim minVal As Double
    Dim minRow As Integer
    Dim Prac As String
    
    ' Set the range to the two columns you want to sum and find the lowest result in
    Set rng = Range("B3:F9")
    
    ' Set the initial minimum value to a very high number
    minVal = 99999
    
    ' Loop through each row in the range and sum the values
    For Each Row In rng.Rows
        sumVal = Row.Cells(1).Value + Row.Cells(5).Value
        
        ' If the sum is lower than the current minimum, update the minimum value and the row number
        If sumVal < minVal Then
            minVal = sumVal
            minRow = Row.Row
            Prac = Row.Cells(0)
        End If
    Next Row
    ' Increase the value in column A in the row where the sum result was lowest by 1
    Range("B" & minRow).Value = Range("B" & minRow).Value + 1
    
    AH = Prac
End Function


Function CAS() As String
    Dim rng As Range
    Dim sumVal As Double
    Dim minVal As Double
    Dim minRow As Integer
    Dim Prac As String
    
    ' Set the range to the two columns you want to sum and find the lowest result in
    Set rng = Range("B3:F9")
    
    ' Set the initial minimum value to a very high number
    minVal = 99999
    
    ' Loop through each row in the range and sum the values
    For Each Row In rng.Rows
        sumVal = Row.Cells(2).Value + Row.Cells(5).Value
        
        ' If the sum is lower than the current minimum, update the minimum value and the row number
        If sumVal < minVal Then
            minVal = sumVal
            minRow = Row.Row
            Prac = Row.Cells(0)
        End If
    Next Row
    ' Increase the value in column A in the row where the sum result was lowest by 1
    Range("C" & minRow).Value = Range("C" & minRow).Value + 1
    
    CAS = Prac
End Function

Function FIN_EIL_Marine()

 Dim rng As Range
    Dim sumVal As Double
    Dim minVal As Double
    Dim minRow As Integer
    Dim Prac As String
    
    ' Set the range to the two columns you want to sum and find the lowest result in
    Set rng = Range("B3:F9")
    
    ' Set the initial minimum value to a very high number
    minVal = 99999
    
    ' Loop through each row in the range and sum the values
    For Each Row In rng.Rows
        sumVal = Row.Cells(3).Value + Row.Cells(5).Value
        
        ' If the sum is lower than the current minimum, update the minimum value and the row number
        If sumVal < minVal Then
            minVal = sumVal
            minRow = Row.Row
            Prac = Row.Cells(0)
        End If
    Next Row
    ' Increase the value in column A in the row where the sum result was lowest by 1
    Range("D" & minRow).Value = Range("D" & minRow).Value + 1
    
    FIN_EIL_Marine = Prac

End Function

Function PROP()

    Dim rng As Range
    Dim sumVal As Double
    Dim minVal As Double
    Dim minRow As Integer
    Dim Prac As String
    
    ' Set the range to the two columns you want to sum and find the lowest result in
    Set rng = Range("B3:F9")
    
    ' Set the initial minimum value to a very high number
    minVal = 99999
    
    ' Loop through each row in the range and sum the values
    For Each Row In rng.Rows
        sumVal = Row.Cells(4).Value + Row.Cells(5).Value
        
        ' If the sum is lower than the current minimum, update the minimum value and the row number
        If sumVal < minVal Then
            minVal = sumVal
            minRow = Row.Row
            Prac = Row.Cells(0)
        End If
    Next Row
    ' Increase the value in column A in the row where the sum result was lowest by 1
    Range("E" & minRow).Value = Range("E" & minRow).Value + 1
    
    PROP = Prac

End Function

Macro in excel works on taht table:
od TSU i RR
A&HCASFIN, EIL, MarinePROPERTYSuma
1. Agata10001
2. Danuta10001
3. Magda00000
4. Gosia00000
5. Małgosia00000
6. Oksana00000
7. Maciej
0​
0000
20002


The issue iam facing is: single mail with 402 in its subject should give me 1 in cell B3 and with my current codes it gives me 1 in cell B3 and 1 in cell B4
Coul anyone assist me with this problem?
 

Excel Facts

Best way to learn Power Query?
Read M is for (Data) Monkey book by Ken Puls and Miguel Escobar. It is the complete guide to Power Query.
Try using:

VBA Code:
xlWB.Application.Run "Rozdzielnik.xlsm!Sheet1.Rozdziel", Left(Subject, 3)
 
Upvote 0

Forum statistics

Threads
1,224,818
Messages
6,181,151
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