VB Loop for each Unique Value in a Range

JoshuaD

Board Regular
Joined
Dec 27, 2016
Messages
54
Good Afternoon,

I am trying to get my code to loop through a column and stop when the active cells value is blank. For instance I am trying to print a list of strings next to dates that I use in another loop. The list of strings is in column "H" starting at H2. However when I try and offset my UniqueVal variable I get an error. Any ideas?

Code:
Sub GenDates_Values()

Dim FirstDate As Date
Dim LastDate As Date
Dim NextDate As Date
Dim UniqueVal As String

UniqueVal = Range("H2")

Do Until UniqueVal.Value=""

    NextDate = FirstDate
    FirstDate = Range("startdate").Value
    LastDate = Range("enddate").Value

    'Cell to begin entering dates
    Range("B3").Select
    'selection of columns within one row
    Do Until NextDate > LastDate

     ActiveCell.Value = NextDate
     'Move one column over
     ActiveCell.Offset(0, -1).Select
     'Set name as the unique character
     ActiveCell.Value = UniqueVal
     'Return to date cell
     ActiveCell.Offset(0, 1).Select
     'Move one row down
     ActiveCell.Offset(1, 0).Select
     NextDate = NextDate + 1

    Loop
    
    
 UniqueVal = UniqueVal.Offset(1, 0).Select
 
 Loop

End Sub
 

Excel Facts

How to calculate loan payments in Excel?
Use the PMT function: =PMT(5%/12,60,-25000) is for a $25,000 loan, 5% annual interest, 60 month loan.
Declare UniqueVal as Range.

Well I cannot believe I overlooked that one! I have made some progress in my code. The only issue is that I am trying to add a condition that once the range UniqueVal hits a blank cell it stops. However my If statement causes it to do nothing. I have tried playing around with Do Until or Do While loops, but I must say that I am not as versed in those.

Code:
Sub GenerateDates()
Dim FirstDate As Date
Dim LastDate As Date
Dim NextDate As Date
Dim UniqueVal As Range
Dim Drange As Range
Dim Rng As Range
Dim Stng As Variant
Set UniqueVal = Range("H2:H20")
Set Rng = Range("B3")

FirstDate = Range("startdate").Value
LastDate = Range("enddate").Value
                'Cell to begin entering dates
Rng.Select
For Each Cell In UniqueVal
If UniqueVal.Cells.Text <> "" Then
                NextDate = FirstDate
                
 
                'selection of columns within one row
                Do Until NextDate > LastDate
                    Rng.Select
                    ActiveCell.Value = NextDate
                    'Move one column over
                    ActiveCell.Offset(0, -1).Select
                    'Set name as the unique character
                    ActiveCell.Value = UniqueVal.Value
                    'Return to date cell
                    ActiveCell.Offset(0, 1).Select
                    'Move one row down
                    ActiveCell.Offset(1, 0).Select
                    Set Rng = ActiveCell
                    NextDate = NextDate + 1
                
                Loop
                
                
 UniqueVal.Offset(1, 0).Select
 Set UniqueVal = ActiveCell
     
                
End If
     
Next
    

End Sub
 
Upvote 0
Thats' because the code doesn't have a statement to break out of the For-Next loop. You need to place an Exit For statement to exit loop if the cell is blank.
 
Upvote 0

Forum statistics

Threads
1,223,903
Messages
6,175,287
Members
452,631
Latest member
a_potato

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