ControlFindItem

通过字符串搜索列表框, 组合框, 下拉列表中的条目, 并返回它的索引.

Index := ControlFindItem(String, ControlID , WinTitle, WinText, ExcludeTitle, ExcludeText)

参数

String

类型: 字符串

要查找的条目全文本. 搜索不区分大小写. 例如, 如果列表框中包含 "UNIX Text" 该条目, 指定单词 unix(小写) 就可以选择它.

ControlID

类型: 字符串, 整数对象

控件的 ClassNN, 文本或 HWND, 或具有 Hwnd 属性的对象. 有关详情, 请参阅控件标识符.

WinTitle, WinText, ExcludeTitle, ExcludeText

类型: 字符串, 整数对象

如果这些都是空白或省略, 将使用上次找到的窗口. 否则, 为 WinTitle 指定窗口标题或其他条件, 来标识目标窗口, 和/或为 WinText 指定目标窗口的单个文本元素的子字符串(由包含的 Window Spy 实用程序显示).

ExcludeTitleExcludeText 可用于根据标题或文本排除一个或多个窗口. 它们的规范类似于 WinTitleWinText, 除了 ExcludeTitle 不识别除窗口标题之外的任何条件.

窗口标题和文本是区分大小写的. 默认情况下, 不检测隐藏窗口, 而检测隐藏文本元素, 除非使用 DetectHiddenWindowsDetectHiddenText 进行更改; 当使用纯 HWND 时, 都会检测隐藏窗口. 默认情况下, 窗口标题的任意位置包含 WinTitleExcludeTitle 就能形成匹配, 除非使用 SetTitleMatchMode 进行了更改.

返回值

类型: 整数

此函数返回 ListBox 或 ComboBox 中与 String 完全匹配的首个条目的索引. 控件中首个条目为 1, 第二个为 2, 依此类推. 如果没有找到匹配, 则抛出异常.

错误处理

如果找不到窗口或控件, 或者控件的类名不包含 "Combo" 或 "List", 则抛出 TargetError.

如果找不到条目, 则抛出 Error.

备注

ControlChooseString 不同, 必须匹配条目的全文, 而不仅仅是开头部分.

为了提高可靠性, 每次使用此函数后都会自动执行延迟. 该延迟可以通过 SetControlDelay 或给 A_ControlDelay 赋值来更改. 有关详情, 请参阅 SetControlDelay 备注.

ControlAddItem, ControlDeleteItem, 控件函数