WinGetText

获取指定窗口的文本.

WinGetText, OutputVar , WinTitle, WinText, ExcludeTitle, ExcludeText

参数

OutputVar

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

WinTitle

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

WinText

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

ExcludeTitle

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

ExcludeText

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

错误处理

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

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

备注

如果没有匹配的窗口, 则 OutputVar 被置空.

通常情况下获取的文本和 Window Spy 中显示的相同. 但是, 如果 DetectHiddenText 为关闭状态, 那么 OutputVar 中会不包含隐藏文本.

每个文本元素都以回车换行符(CR+LF) 结束, 它们在脚本中表示为 `r`n. 要提取个别行或子字符串, 请使用类似 InStr()SubStr() 的命令或内置函数. 还可以使用解析循环来逐个检查每行或每个单词.

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

可获取的最多文本数限制于变量的最大容量(这可以通过 #MaxMem 指令改变). 因此, 如果目标窗口(例如打开了大文档的编辑器) 包含大量文本, 那么此命令可能会使用大量的内存. 要避免这种情况, 考虑使用 ControlGetText 只获取部分的窗口文本. 在任何情况下, 可以为变量赋值为空来释放它占用的内容, 即 OutputVar =.

要获取窗口中所有控件的列表, 请参照此例: WinGet, OutputVar, ControlList, WinTitle

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

相关

ControlGetText, WinGetActiveStats, WinGetActiveTitle, WinGetTitle, WinGetPos, #MaxMem

示例

#1

Run, Calc.exe
WinWait, Calculator
WinGetText, text  ; 使用前面找到的窗口.
MsgBox, The text is:`n%text%