2012-02-13 104 views
5

我有一个名为lstSerial的列表框和一个名为txtSerials的文本框。我想要做的是在lstSerial中搜索txtSerials中输入的字符串。我在Microsoft Visual Basic 6.0中使用VB6,并且在查找文档时遇到了很多困难。在列表框中搜索指定的字符串VB6

谢谢。

回答

7

@ AlexK的答案是技术上是正确的 - 是 - 它会工作,但它不是去的首选方式。有一个API调用这个目的:

Private Declare Function SendMessage Lib "USER32" Alias "SendMessageA" _ 
    (ByVal hWnd As Long, ByVal wMsg As Long, ByVal wParam As _ 
    Integer, ByVal lParam As Any) As Long 

'constants for searching the ListBox 
Private Const LB_FINDSTRINGEXACT = &H1A2 
Private Const LB_FINDSTRING = &H18F 

'function to get find an item in the Listbox 
Public Function GetListBoxIndex(hWnd As Long, SearchKey As String, Optional FindExactMatch As Boolean = True) As Long 

    If FindExactMatch Then 
     GetListBoxIndex = SendMessage(hWnd, LB_FINDSTRINGEXACT, -1, ByVal SearchKey) 
    Else 
     GetListBoxIndex = SendMessage(hWnd, LB_FINDSTRING, -1, ByVal SearchKey) 
    End If 

End Function 

所以,你要做到这一点:

lstSerial.ListIndex = GetListBoxIndex(lstSerial.hWnd, txtSerials.Text) 

Source

+0

+1运行速度更快 – MarkJ 2012-02-14 08:18:19

6

Docs; http://msdn.microsoft.com/en-us/library/aa267225(v=VS.60).aspx

dim find as string,i as long,found as boolean 
find=txtSerials.text 

for i=0 to lstserial.listcount - 1 
    if strcomp(find, lstSerial.list(i), vbTextcompare)=0 then 
     found = true 
     lstSerial.setfocus 
     lstSerial.listindex= i 
     exit for 
    end if 
next 

if not found then msgbox "not found ..." 
+1

+1我用这个方法也一样,我从来没有发现它的性能很糟糕,所以更喜欢通过API调用 – 2012-02-15 14:03:01