VBA: Random Name Selector with no repeat

gd6noob

Board Regular
Joined
Oct 20, 2017
Messages
170
Office Version
  1. 2016
Platform
  1. Windows
Hi everyone,

I would like to create a Random Name Selector with no repeat. I would like to make this a little more fancier visually and not sure if it would work.
  1. What I had in mind is when I press button, the cell A2 would highlight and then move to the next cell down the range, from faster to slower and then it stop. Then that name will be in D2. Then I would press the button again and does the same and the next name would go into D3. All I need 2 names.
  2. Next, in column A, if they were previously selected, then it would indicate yes for in future, it would not include them in the random name selector. e.g. today I ran this and Name 3 and Name 9 were select, A4 and A10 would show yes and tomorrow when I run this again, they would not be included in the next random name selector.

Random Name Selector with No Repeat1.xlsb
ABCDE
1Previously Selected?Name
2Name 1Name 1Name 1
3Name 2Name 2Name 2
4YesName 3
5Name 4
6Name 5
7Name 6
8Name 7
9Name 8
10YesName 9
11YesName 10
12Name 11
13Name 12
Sheet1
 

Excel Facts

What do {} around a formula in the formula bar mean?
{Formula} means the formula was entered using Ctrl+Shift+Enter signifying an old-style array formula.
Hi,​
if names are unique in column B so column A is useless …​
 
Upvote 0
Yes, the names will all be unique but I would not want the names to repeat until I have gone through the entire list of names.
E.G. lets say I have 52 names and on Week 1 Monday, it selected Name 3.
Following Monday, Week 2, instead of having 52 names to select from, only 51 because Name 3 was selected last week. So then it selects Name 9.
Following Monday, Week 3, instead of having 51 names to select from, only 50 because Name 9 was selected last week. So then it selects Name 10.
If there is less then 52 names, lets say 20 names. After going through all 20 names, it would reset and have 20 names to select from at the start.

I hope this makes sense. If Column A is still not needed, then I'm good to remove this. Whatever is easiest.
 
Upvote 0
Seems a bit over the top with the cell highlighting step, but it seemed like a fun little exercise. There are definitely more efficient ways of doing this.

But, this seems to do the trick on your sample data.

VBA Code:
Public n As Integer

Sub wod()
Dim r As Range:         Set r = Range("B2:B13")
Dim inc As Single:      inc = 0.1
Dim ro As Integer:      ro = 1

While inc < 1
    Randomize
    If ro > r.Cells.Count Then ro = 1
    r.Cells.Interior.ColorIndex = -4142
    r.Cells(ro).Interior.ColorIndex = 6
    For i = 0 To (inc * 1500) ^ 2
    Next i
    ro = ro + 1
    inc = inc * (1 + Rnd() / 100)
    DoEvents
Wend

If Range("A" & ro).Value = "Yes" Then
    If Application.WorksheetFunction.CountA(r.Offset(, -1)) < r.Cells.Count Then
        ro = FindNext(r, ro - 1)
        Range("A" & ro).Value = "Yes"
        r.Cells.Interior.ColorIndex = -4142
        r.Cells(ro - 1).Interior.ColorIndex = 6
    Else
        r.Offset(, -1).ClearContents
        Range("E2:E3").ClearContents
        n = 0
    End If
Else
    Range("A" & ro).Value = "Yes"
End If

Select Case n
    Case 0
        Range("E2").Value = r.Cells(ro - 1).Value
    Case 1
        Range("E3").Value = r.Cells(ro - 1).Value
    Case 2
        Range("E2:E3").ClearContents
        Range("E2").Value = r.Cells(ro - 1).Value
        n = 0
End Select

n = n + 1
End Sub

Function FindNext(r As Range, ro As Integer)

For i = 1 To r.Rows.Count
    ro = ro + 1
    If ro > r.Rows.Count Then ro = 1
    If r.Cells(ro).Offset(, -1).Value = "" Then
        FindNext = ro + 1
        Exit Function
    End If
Next i
End Function
 
Upvote 0
Solution
If Column A is still not needed, then I'm good to remove this. Whatever is easiest.
Column A could be useless if previous names are in column E but if each time column E is cleared then column A is necessary …​
 
Upvote 0
Seems a bit over the top with the cell highlighting step, but it seemed like a fun little exercise. There are definitely more efficient ways of doing this.

But, this seems to do the trick on your sample data.

VBA Code:
Public n As Integer

Sub wod()
Dim r As Range:         Set r = Range("B2:B13")
Dim inc As Single:      inc = 0.1
Dim ro As Integer:      ro = 1

While inc < 1
    Randomize
    If ro > r.Cells.Count Then ro = 1
    r.Cells.Interior.ColorIndex = -4142
    r.Cells(ro).Interior.ColorIndex = 6
    For i = 0 To (inc * 1500) ^ 2
    Next i
    ro = ro + 1
    inc = inc * (1 + Rnd() / 100)
    DoEvents
Wend

If Range("A" & ro).Value = "Yes" Then
    If Application.WorksheetFunction.CountA(r.Offset(, -1)) < r.Cells.Count Then
        ro = FindNext(r, ro - 1)
        Range("A" & ro).Value = "Yes"
        r.Cells.Interior.ColorIndex = -4142
        r.Cells(ro - 1).Interior.ColorIndex = 6
    Else
        r.Offset(, -1).ClearContents
        Range("E2:E3").ClearContents
        n = 0
    End If
Else
    Range("A" & ro).Value = "Yes"
End If

Select Case n
    Case 0
        Range("E2").Value = r.Cells(ro - 1).Value
    Case 1
        Range("E3").Value = r.Cells(ro - 1).Value
    Case 2
        Range("E2:E3").ClearContents
        Range("E2").Value = r.Cells(ro - 1).Value
        n = 0
End Select

n = n + 1
End Sub

Function FindNext(r As Range, ro As Integer)

For i = 1 To r.Rows.Count
    ro = ro + 1
    If ro > r.Rows.Count Then ro = 1
    If r.Cells(ro).Offset(, -1).Value = "" Then
        FindNext = ro + 1
        Exit Function
    End If
Next i
End Function
Thank you, this is great.
And yes, the highlighting cells is mostly for visual effects to make it seem more exciting for everyone watching.
 
Upvote 0

Forum statistics

Threads
1,223,228
Messages
6,170,871
Members
452,363
Latest member
merico17

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