WinKill

指定したウィンドウを強制的に閉じます。

WinKill WinTitle, WinText, SecondsToWait, ExcludeTitle, ExcludeText

パラメータ

WinTitle, WinText, ExcludeTitle, ExcludeText

型:文字列整数またはオブジェクト

もしこれらの項目が未設定または省略されたときは、最後に見つかったウィンドウが使用されます。そうでないときは、WinTitleウィンドウタイトルまたはターゲットウィンドウを識別するための他の基準、および/またはWinTextにターゲットウィンドウの単一のテキスト要素からの部分文字列(付属のWindow Spyユーティリティを使えばわかります)を指定します。

ExcludeTitleExcludeTextはウィンドウのタイトルまたはテキストで除外するために使用します。指定の仕方はWinTitleWinTextに似ていますが、ExcludeTitleはウィンドウのタイトル以外の基準(ウィンドウクラスやHWNDなど)を認識しません。

ウィンドウのタイトルとテキストは大文字と小文字を区別します。DetectHiddenWindows関数 と DetectHiddenText関数で変更しない限り、初期設定では非表示ウィンドウは検出されず、非表示テキストは検出されます。SetTitleMatchMode関数で変更しない限り、初期設定ではウィンドウのタイトルはその中のどこかにWinTitleまたはExcludeTitleを含んでいれば一致します。

SecondsToWait

型:整数または浮動小数点数

省略されたときは、すぐにウィンドウを閉じます。そうでないときは、ウィンドウを閉じるまでの秒数(小数点を含む)を指定します。その期間内にウィンドウが閉じなければ、スクリプトは続行されます。

エラー処理

グループモードが使用されている場合を除き、ウィンドウが見つからなかった場合はTargetErrorがスローされます。

ウィンドウが見つかっても閉じられない場合は例外がスローされないので、ウィンドウが閉じたかどうかを確実に判断する必要がある場合は、WinExistまたはWinWaitCloseを使用してください。

備考

この関数はまず、ウィンドウを普通に閉じようとします。それが失敗したときは、ウィンドウのプロセスを終了して閉じようとします。

一致するウィンドウがアクティブな場合、そのウィンドウは他の一致するウィンドウよりも優先して閉じられます。一般に、複数のウィンドウがマッチした場合、一番上の(最近使われた)ウィンドウが閉じられます。

ただし、WinTitleahk_group GroupNameの場合は、グループ内のすべてのウィンドウが対象となります。

関数が待機状態にある間、ホットキーカスタムメニュー項目、またはタイマーによって新しいスレッドを起動することができます。

WinCloseWinWaitCloseProcessCloseWinActivateSetTitleMatchModeDetectHiddenWindowsラストファウンドウィンドウWinExistWinActiveWinWaitActiveWinWaitGroupActivate

メモ帳が起動しているときはそれを強制的に閉じ、そうでない場合は電卓を強制的に閉じます。

if WinExist("Untitled - Notepad")
    WinKill ; WinExistで見つかったウィンドウを使用します。
else
    WinKill "Calculator"