Need help transforming my code

ouadad

Board Regular
Joined
Jun 19, 2005
Messages
213
I guess I've just been using For-Next loops because they were easy to set up, but now I've come across a problem that requires a more sophisticated approach and I'm at a loss to how to set it up. Below is the code I've been using.

It works by finding a specific year and then captures and stores a string value (sn) from column 1 and an integer value (points) from column 3 (out of 234678 values). Then it compares the value in sn to one of 112345 similar values in column 16. If the string values match, it pastes the points value into the column beside it.

So right now, it compares each of 234678 string values to each 112345 string values.

I thought about using a While-Wend loop, but I'm not sure how to set it up with the comparison and I'm looking for a little assistance.

Code:
Sub Tier1_Points_Used_Per_Year()
Dim irow1 As Long, irow2 As Long, fy As Integer, sn As String, points As Integer
    For irow1 = 2 To 234678
        If Cells(irow1, 2) = 2018 Then
            sn = Cells(irow1, 1)
            points = Cells(irow1, 3)
            For irow2 = 2 To 112345
                If Cells(irow2, 16) = sn Then
                    Cells(irow2, 17) = points
                End If
            Next irow2
        End If
    Next irow1
End Sub


Here is a sample of the data for the year 2013. The data is sorted by sn in both columns.

Code:
sn	FY	Total_Points		Starting Points	2013-sn	2013-points
A10009044	2015	146		300	A10009044	
A10009044	2018	81		300	A10023027	
A10009044	2019	433		300	A10036355	
A10023027	2014	150		300	A10040199	
A10036355	2013	485		300	A10047268	
A10036355	2014	136		300	A10048544	
A10036355	2015	191		300	A10052525	
A10036355	2018	126		300	A10055317	
A10040199	2015	197		300	A10055507
 
Last edited:

Excel Facts

Lock one reference in a formula
Need 1 part of a formula to always point to the same range? use $ signs: $V$2:$Z$99 will always point to V2:Z99, even after copying
How about
Code:
Sub ouadad()
   Dim Ary As Variant, Oary As Variant
   Dim i As Long
   
   Ary = Range("A2", Range("A" & Rows.Count).End(xlUp).Offset(, 2)).Value2
   Oary = Range("P2", Range("P" & Rows.Count).End(xlUp).Offset(, 1)).Value2
   With CreateObject("scripting.dictionary")
      For i = 1 To UBound(Ary)
         If Ary(i, 2) = 2018 Then .Item(Ary(i, 1)) = Ary(i, 3)
      Next i
      For i = 1 To UBound(Oary)
         Oary(i, 2) = .Item(Oary(i, 1))
      Next i
   End With
   Range("P2").Resize(UBound(Oary), 2).Value2 = Oary
End Sub
 
Upvote 0
That's incredible. I don't understand what you did but I will be studying it for future reference. Thank you!!!
 
Upvote 0

Forum statistics

Threads
1,225,762
Messages
6,186,895
Members
453,384
Latest member
BigShanny

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