WinGetText

从指定窗口检索文本.

Text := WinGetText(WinTitle, WinText, ExcludeTitle, ExcludeText)

参数

WinTitle, WinText, ExcludeTitle, ExcludeText

类型: 字符串, 整数对象

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

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

窗口标题和文本是区分大小写的. 默认情况下, 不检测隐藏窗口, 而检测隐藏文本元素, 除非使用 DetectHiddenWindowsDetectHiddenText 进行更改; 但是, 当使用纯 HWND 时, 无论 DetectHiddenWindows 怎样设置, 都会检测隐藏窗口. 默认情况下, 窗口标题的任意位置包含 WinTitleExcludeTitle 就能形成匹配, 除非使用 SetTitleMatchMode 进行了更改.

返回值

类型: 字符串

函数返回指定窗口的文本.

错误处理

如果找不到窗口, 则抛出 TargetError.

如果在检索窗口文本时出现问题, 则抛出 Error.

备注

通常情况下获取的文本和 Window Spy 中显示的相同. 但是, 如果 DetectHiddenText 为关闭状态, 则返回值中省略了隐藏的文本.

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

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

如果目标窗口(例如打开大文档的编辑器) 包含大量文本, 则此函数可能会使用大量 RAM. 为了避免这种情况, 可以通过使用 ControlGetText 来仅检索窗口文本的一部分. 无论如何, 以后可以通过将变量赋值为空来释放变量的内存, 例如 Text := "".

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

要获取窗口中所有控件的数组, 请使用 WinGetControlsWinGetControlsHwnd.

ControlGetText, WinGetTitle, WinGetPos

示例

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

Run "calc.exe"
WinWait "Calculator"
MsgBox "The text is:`n" WinGetText()  ; 使用由 WinWait 找到的窗口.