Filter/Find in Array
The following piece of code can be run from any general module. This code extracts all array elements based on the search criteria. You can also search the entire array element or part of it depending on the 3rd parameter of the function if its set to True or False.
Sub TestRun() Dim arr Dim varSearch '-------------Variable parameters---------- arr = Array(1, 2, 3, 10, 110, 111) varSearch = 1 '========================================== MsgBox Join(FilterArray(arr, varSearch, True), vbCr) End Sub Function FilterArray(arrVariant, varSearch, Optional blnEntireElement As Boolean = True) If blnEntireElement Then FilterArray = FilterArrayExact(arrVariant, varSearch) Else FilterArray = Filter(arrVariant, varSearch, True) End If End Function Function FilterArrayExact(arrVariant, varSearch) Dim arrSearch As Variant Dim arrFiltered As Variant Const strEncl As String = ":;" Const strDelim As String = ",," 'first filter the array for elements containing search variant arrFiltered = Filter(arrVariant, varSearch) If UBound(arrFiltered) > -1 Then 'mark the beginning and end of each array element found 'strEncl and strDelim should not be in the array arrSearch = Split(strEncl & Join(arrFiltered, strEncl & _ strDelim & strEncl) & strEncl, strDelim) 'again filter array, include Encl in search arrFiltered = Filter(arrSearch, _ strEncl & varSearch & strEncl) 'clear Encl from final result FilterArrayExact = Split(Replace(Join(arrFiltered, _ strDelim), strEncl, ""), strDelim) End If End Function
»
- Vishesh's blog
- Login or register to post comments
- 15511 reads
Recent comments
5 years 36 weeks ago
6 years 22 weeks ago
6 years 34 weeks ago
6 years 37 weeks ago
6 years 38 weeks ago
6 years 43 weeks ago
6 years 52 weeks ago
7 years 2 days ago
7 years 3 days ago
7 years 3 days ago