WinGetText

获取指定窗口的文本.

WinGetText, OutputVar , WinTitle, WinText, ExcludeTitle, ExcludeText

参数

OutputVar

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

WinTitle, WinText, ExcludeTitle, ExcludeText

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

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

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

错误处理

[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 := "".

没有必要执行 SetTitleMatchMode Slow, 因为 WinGetText 总是使用慢速模式检索文本(因为它适用于更广泛的控件类型).

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

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

示例

打开计算器, 等待其存在, 并检索和报告其文本.

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