Problem: Looking for a more efficient way of finding whether there is an exact matching value in a 1d array -- essentially a boolean true/false
.
Am I overlooking something obvious? Or am I simply using the wrong data structure, by using an array when I probably should be using a collection object or a dictionary? In the latter I could check the .Contains
or .Exists
method, respectively
In Excel I can check for a value in a vector array like:
If Not IsError(Application.Match(strSearch, varToSearch, False)) Then
' Do stuff
End If
This returns an exact match index, obviously subject to limitations of Match
function which only finds the first matching value in this context. This is a commonly used method, and one that I have been using for a long time, too.
This is satisfactory enough for Excel -- but what about other applications?
In other applications, I can do basically the same thing but requires enabling reference to the Excel object library, and then:
If Not IsError(Excel.Application.match(...))
That seems silly, though, and is difficult to manage on distributed files because of permissions/trust center/etc.
I have tried to use the Filter() function:
If Not Ubound(Filter(varToSearch, strSearch)) = -1 Then
'do stuff
End If
But the problem with this approach is that Filter
returns an array of partial matches, rather than an array of exact matches. (I have no idea why it would be useful to return substring/partial matches.)
The other alternative is to literally iterate over each value in the array (this also is very commonly used I think) -- which seems even more needlessly cumbersome than calling on Excel's Match
function.
For each v in vArray
If v = strSearch Then
' do stuff
End If
Next
Question&Answers:
os 与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…