我有一个名为lstSerial的列表框和一个名为txtSerials的文本框。我想要做的是在lstSerial中搜索txtSerials中输入的字符串。我在Microsoft Visual Basic 6.0中使用VB6,并且在查找文档时遇到了很多困难。在列表框中搜索指定的字符串VB6
谢谢。
我有一个名为lstSerial的列表框和一个名为txtSerials的文本框。我想要做的是在lstSerial中搜索txtSerials中输入的字符串。我在Microsoft Visual Basic 6.0中使用VB6,并且在查找文档时遇到了很多困难。在列表框中搜索指定的字符串VB6
谢谢。
@ 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)
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我用这个方法也一样,我从来没有发现它的性能很糟糕,所以更喜欢通过API调用 – 2012-02-15 14:03:01
+1运行速度更快 – MarkJ 2012-02-14 08:18:19