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, WinText, ExcludeTitle, ExcludeText

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

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

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

错误处理

[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.

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

示例

从记事本的编辑控件中获取当前文本, 并将其存储在 OutputVar 中. 这个例子在 Windows 11 或更高版本系统可能会失败, 因为它需要经典版本的记事本.

ControlGetText, OutputVar, Edit1, Untitled -

主窗口的编辑控件检索和报告当前文本.

ListVars
WinWaitActive ahk_class AutoHotkey
ControlGetText, OutputVar, Edit1 ; 使用上面找到的窗口.
MsgBox % OutputVar