ControlGetItems

返回 ListBox, ComboBox 或 DropDownList 中项目/行数组.

Items := ControlGetItems(Control , WinTitle, WinText, ExcludeTitle, ExcludeText)

参数

Control

类型: 字符串, 整数对象

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

WinTitle, WinText, ExcludeTitle, ExcludeText

类型: 字符串, 整数对象

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

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

窗口标题和文本是区分大小写的. 默认情况下, 不检测隐藏窗口, 而检测隐藏文本元素, 除非使用 DetectHiddenWindowsDetectHiddenText 进行更改. 默认情况下, 窗口标题必须以指定的 WinTitleExcludeTitle 开头才能匹配, 除非使用 SetTitleMatchMode 进行更改.

返回值

类型: Array

函数返回项目/行的数组.

错误处理

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

失败时抛出 Error, 例如, 如果消息返回错误码或不能被发送.

备注

有些应用程序私自存储了它们的项目数据, 这使得它们的文本无法被检索. 在这种情况下, 通常不会抛出异常, 但所有检索到的字段都是空的.

ListViewGetContent, WinGetList, 控件函数

示例

逐个访问项目.

for item in ControlGetItems("ComboBox1", WinTitle)
    MsgBox "Item number " A_Index " is " item

通过索引访问特定的项目.

items := ControlGetItems("ListBox1", WinTitle)
MsgBox "The first item is " items[1]
MsgBox "The last item is " items[-1]