检索控件的文本.
Text := ControlGetText(Control , WinTitle, WinText, ExcludeTitle, ExcludeText)
Hwnd
属性的对象. 有关详情, 请参阅 Control 参数.
如果这些都是空白或省略, 将使用上次找到的窗口. 否则, 为 WinTitle 指定窗口标题或其他条件, 来标识目标窗口, 和/或为 WinText 指定目标窗口的单个文本元素的子字符串(由包含的 Window Spy 实用程序显示).
ExcludeTitle 和 ExcludeText 可用于根据标题或文本排除一个或多个窗口. 它们的规范类似于 WinTitle 和 WinText, 除了 ExcludeTitle 不识别除窗口标题之外的任何条件.
窗口标题和文本是区分大小写的. 默认情况下, 不检测隐藏窗口, 而检测隐藏文本元素, 除非使用 DetectHiddenWindows 和 DetectHiddenText 进行更改. 默认情况下, 窗口标题的任意位置包含 WinTitle 或 ExcludeTitle 就能形成匹配, 除非使用 SetTitleMatchMode 进行了更改.
类型: 字符串
函数返回指定控件的文本.
失败时, 或者找不到窗口或控件, 则抛出 TargetError.
注意: 要获取列表视图, 列表框或组合框的文本, 请使用 ListViewGetContent 或 ControlGetItems.
如果获取的文本看起来像被截短了(不完整), 可能需要通过 SendMessage 发送 WM_GETTEXT 消息来检索文本. 因为某些应用程序不能正确响应 WM_GETTEXTLENGTH 消息, 所以这是必要的, 否则会导致 AutoHotkey 把输出变量设得过小以致无法保存所有的文本.
如果目标控件(例如打开大文档的编辑器) 包含大量文本, 则此函数可能会使用大量的 RAM. 但是, 变量的内存在使用后可以通过将其赋值为空来释放, 例如 Text := ""
.
从大多数控件类型检索的文本使用回车和换行符(`r`n) 而不是单独的换行符(`n) 来表示每行的结尾.
不必执行 SetTitleMatchMode "Slow"
, 因为 ControlGetText 始终使用慢速模式检索文本(因为它适用于更广泛的控件类型).
若要检索窗口中所有控件的数组, 请使用 WinGetControls 或 WinGetControlsHwnd.
ControlSetText, WinGetText, 控件函数
从记事本的编辑控件中获取当前文本, 并将其存储在 Text. 这个例子在 Windows 11 或更高版本系统可能会失败, 因为它需要经典版本的记事本.
Text := ControlGetText("Edit1", "Untitled -")
从主窗口的编辑控件检索和报告当前文本.
ListVars WinWaitActive "ahk_class AutoHotkey" MsgBox ControlGetText("Edit1") ; 使用上面找到的窗口.