ControlGetText

检索控件的文本.

Text := ControlGetText(Control , WinTitle, WinText, ExcludeTitle, ExcludeText)

参数

Control

类型: 字符串, 整数对象

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

WinTitle

类型: 字符串, 整数对象

识别目标窗口的窗口标题或其他条件. 请参阅 WinTitle.

WinText

类型: 字符串

如果存在, 此参数必须是目标窗口的单个文本元素的子字符串(和内置的 Window Spy 工具显示的一样). 如果 DetectHiddenText 为 ON, 那么会检测隐藏文本元素.

ExcludeTitle

类型: 字符串

标题中含有此参数值的窗口将被排除.

ExcludeText

类型: 字符串

文本中含有此参数值的窗口将被排除.

返回值

类型: 字符串

函数返回指定控件的文本.

错误处理

失败时, 或者找不到窗口或控件, 则抛出 TargetError.

备注

注意: 要获取列表视图, 列表框或组合框的文本, 请使用 ListViewGetContentControlGetItems.

如果获取的文本看起来像被截短了(不完整), 可能需要通过 SendMessage 发送 WM_GETTEXT 消息来检索文本. 因为某些应用程序不能正确响应 WM_GETTEXTLENGTH 消息, 所以这是必要的, 否则会导致 AutoHotkey 把输出变量设得过小以致无法保存所有的文本.

如果目标控件(例如打开大文档的编辑器) 包含大量文本, 则此函数可能会使用大量的 RAM. 但是, 变量的内存在使用后可以通过将其赋值为空来释放, 例如 Text := "".

从大多数控件类型检索的文本使用回车和换行符(`r`n) 而不是单独的换行符(`n) 来表示每行的结尾.

不必执行 SetTitleMatchMode "Slow", 因为 ControlGetText 始终使用慢速方法检索文本(因为它适用于更广泛的控件类型).

若要检索窗口中所有控件的列表, 请使用 WinGetControlsWinGetControlsHwnd.

窗口标题和文本是区分大小写的. 除非 DetectHiddenWindows 被打开, 否则不会检测隐藏窗口.

ControlSetText, WinGetText, Control 函数

示例

从记事本的编辑控件中获取当前文本, 并将其存储在 Text.

Text := ControlGetText("Edit1", "Untitled -")
unixetc