检查VB6集合中是否存在记录?

我在现在的工作场所继承了一个大型的VB6应用程序。我有点在工作中学习VB6,并有一些我遇到的问题。目前的主要问题是无法确定如何检查Collection对象中是否存在密钥。谁能帮忙?
@Mark Biek你的keyExists与我的标准Exists()函数密切相关。为了使该类对于COM暴露的集合和检查数字索引更有用,我建议将sKey和myCollection更改为不输入。如果该函数将与对象集合一起使用,则需要“set”(在设置val的行上)。

编辑:这是在告诉我,我从来没有注意到基于对象和基于值的Exists()函数的不同要求。我很少使用非对象的集合,但这似乎是一个错误的完美瓶颈,当我需要检查存在时,这个错误很难跟踪。因为如果错误处理程序已经处于活动状态,错误处理将失败,因此需要两个函数获取新的错误范围。只有Exists()函数需要被调用

Public Function Exists(col,index) As Boolean
On Error GoTo ExistsTryNonObject
    Dim o As Object

    Set o = col(index)
    Exists = True
    Exit Function

ExistsTryNonObject:
    Exists = ExistsNonObject(col,index)
End Function

Private Function ExistsNonObject(col,index) As Boolean
On Error GoTo ExistsNonObjectErrorHandler
    Dim v As Variant

    v = col(index)
    ExistsNonObject = True
    Exit Function

ExistsNonObjectErrorHandler:
    ExistsNonObject = False
End Function

并验证功能

Public Sub TestExists()
    Dim c As New Collection

    Dim b As New Class1

    c.Add "a string","a"
    c.Add b,"b"

    Debug.Print "a",Exists(c,"a") ' True '
    Debug.Print "b","b") ' True '
    Debug.Print "c","c") ' False '
    Debug.Print 1,1) ' True '
    Debug.Print 2,2) ' True '
    Debug.Print 3,3) ' False '
End Sub

相关文章

Format[$] ( expr [ , fmt ] ) format 返回变体型 format$ 强...
VB6或者ASP 格式化时间为 MM/dd/yyyy 格式,竟然没有好的办...
在项目中添加如下代码:新建窗口来显示异常信息。 Namespace...
转了这一篇文章,原来一直想用C#做k3的插件开发,vb没有C#用...
Sub 分列() ‘以空格为分隔符,连续空格只算1个。对所选...
  窗体代码 1 Private Sub Text1_OLEDragDrop(Data As Dat...