I currently have an array that is being set by selected items from a listbox. I need to know how to check to see if there are consecutive values in the array then delete the values that are between the lowest and highest values of the consecutive numbers.
Here is an example to show what I mean:
Dim sheets() As Long
Dim Selected As String
ReDim sheets(i)
For i = 1 To ListBox1.ListCount - 1
If ListBox1.Selected(i) = True Then
Selected = ListBox1.List(i)
ReDim Preserve sheets(i)
sheets(i) = Selected
End If
Next i
The array is used for a Solidworks API function that sets the print sheet range. This is why I cant have more than 2 consecutive numbers.
That being said if there is an easier way to do this based on deselecting the consecutive listbox items I am all ears for that too.
Thank you
With these values in the listbox (all selected), you get:
Edit:
To double the items not part of a sequence make sure to increase the initial array size to accommodate for this case:
Note:
If you use the
ListFillRange
property to fill in the items in the listbox make sure you don't use entire columns, for example don't use"A:A"
because this will add 1+ M items to the list (even empty cells)If Microsoft decides to increase the grid size to a billion rows in a new Excel version, working with the listbox will take a long time
Instead always populate it with the used range from the respective column:
ListBox1.ListFillRange = Sheet1.UsedRange.Columns(1).Address