ControlGetText

AutoHotKey

ControlGetText

获取控件的文本.

ControlGetText, OutputVar [, Control, WinTitle, WinText, ExcludeTitle, ExcludeText]

参数

OutputVar

用来存储获取的文本的变量名.

Control

可以是 ClassNN(控件的类名和实例编号)或控件的文本,它们都可以通过 Window Spy 获取.使用文本时,匹配行为由 SetTitleMatchMode 决定.如果此参数为空或省略, 则使用目标窗口的顶层控件.

要对控件的 HWND(窗口句柄)进行操作,请将 Control 参数留空同时在 WinTitle 参数中指定 ahk_id %ControlHwnd%(即使在 DetectHiddenWindows 设置关闭时,这样也可以操作隐藏控件).获取控件的 HWND 的一般方法是使用 ControlGet Hwnd, MouseGetPosDllCall.

WinTitle

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

WinText

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

ExcludeTitle

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

ExcludeText

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

ErrorLevel

[v1.1.04+] 此命令失败时会抛出异常. 想了解更多信息, 请参阅 运行时错误.

如果遇到问题则 ErrorLevel 被置为 1, 否则为 0.

备注

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

如果获取的文本看起来像被截短了(不完整),请在 ControlGetText 前尝试使用 VarSetCapacity(OutputVar, 55) [把 55 替换为超过截短文本许多的大小].在一些应用程序不能正确响应 WM_GETTEXTLENGTH 消息时需要这样, 否则会导致 AutoHotkey 把输出变量设的过小以致无法保存所有的文本.

可获取的最多文本数限制于变量的最大容量 (这可以通过 #MaxMem 指令改变). 因此,如果目标控件(例如打开了大文档的编辑器)包含大量文本,那么此命令可能会使用大量的内存.不过,在使用后可以为变量赋值为空来释放它占用的内存,即 OutputVar =.

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

执行 SetTitleMatchMode Slow 是不需要的,因为 ControlGetText 总是使用慢速模式获取文本(这样它可以工作于更大范围的控件类型).

要获取窗口中所有控件的列表, 请使用 WinGet ControlList.

窗口标题和文本是区分大小写的. 只有在打开 DetectHiddenWindows 设置时,才能检测到隐藏窗口.

相关

ControlSetText, WinGetText, Control, ControlGet, ControlMove, ControlFocus, ControlClick, ControlSend, #MaxMem

示例

ControlGetText, OutputVar, Edit1, Untitled -