![]() |
|
基礎解説 チェック式 WSH入門 第12回 WshShellオブジェクトを利用する(1) 1.Runメソッド Microsoft MVPWindows Server - Admin Frameworks 牟田口 大介 2007/09/12 |
|
|
Page1
Page2
|
|
|
今回から数回にわたって、WSH(Windows Script Host)の内部オブジェクトであるWshShellオブジェクトとそこから派生するオブジェクトについて解説していく。 WshShellオブジェクトまずはWshShellオブジェクト(ProgIDは“WScript.Shell”)と、それから派生するオブジェクト群(WshEnvironmentオブジェクト、WshSpecialFoldersオブジェクト、WshShortcutオブジェクト、WshUrlShortcutオブジェクト、WshScriptExecオブジェクト)の階層構造とそれらのメンバ(プロパティ/メソッド)を図で概観してみよう。 |
![]() |
| WshShellオブジェクトのメンバと、それから派生するオブジェクトのメンバ |
| WshShellオブジェクト(ProgIDは“WScript.Shell”)をWScript.CreateObjectメソッドを使って生成すると、これだけのメンバ(プロパティ/メソッド)にアクセス可能である。4カ所の大きな矢印( |
このように、WshShellオブジェクトは、多数のオブジェクト、メンバを内包していることが分かる。今回からはWshShellオブジェクトのメンバを中心に解説し、次回以降に派生するオブジェクトとそのメンバの使い方について述べたいと思う。
アプリケーションを起動するRunメソッド
まずは、基本となる、WSHからのアプリケーション起動方法について述べる。WSHからアプリケーションを起動するにはRunメソッドとExecメソッドが使用できる。実行時にアプリケーションのウィンドウ・スタイルなどを指定可能なのがRunメソッド、実行中にオブジェクトを通じてアプリケーションと通信を行えるのがExecメソッドである。Runメソッドの方がより簡略にアプリケーションを実行可能だ。今回はこのRunメソッドについて見ていこう。
ここでは、Windows OSに付属する標準のテキスト・エディタである「メモ帳(実行ファイル名はnotepad.exe)」を起動する例を見てみよう。notepad.exeの存在するパスは環境によって異なるので適宜書き換えてもらいたい。
※ファイルRunNotepad.vbs |
実行結果は例えば次のようになる。
![]() |
![]() |
| Runメソッドでメモ帳を起動する | |
| このようにメモ帳のウィンドウが開き、続いて、起動した旨を伝えるメッセージ・ボックスが表示される。 | |
このスクリプトでは、最初にWshShellオブジェクトをWScriptオブジェクトのCreateObjectメソッドで作成し、オブジェクト変数objWshShellに代入している。これでWshShellオブジェクトを利用可能になる。CreateObjectメソッドについての詳細は前回の「3.COMオブジェクトの操作(1)」を参照してもらいたい。
このようにRunメソッドは引数に実行ファイル(拡張子exeのファイル)のパスを記述すると、そのアプリケーションを実行する。
Runメソッドの引数は環境変数(% 〜 %で環境変数名をくくる)を展開するので、
objWshShell.Run "%windir%\system32\notepad.exe" |
と書くこともできる。
なお、パスの通っているフォルダ(環境変数PATHにフォルダのフルパスが定義されているフォルダ)の実行ファイルを実行する場合、フォルダのフルパスは省略可能である。Windows XPやWindows Server 2003、Windows Vistaの32bitバージョン(x86)ではそれぞれC:\Windows\System32にパスが通っているので、
objWshShell.Run "notepad.exe" |
と記述しても起動できる。また、スクリプトのあるフォルダにある実行ファイルも同じくフォルダ・パスは省略できる。カレント・ディレクトリにある実行ファイルも同様である(WSHからカレント・ディレクトリを設定する方法については後の回で述べる)。
実行ファイルのパスに半角スペースが含まれている場合は注意が必要だ。Runメソッドはそのような場合、実行ファイルのパスを ""(ダブル・クォーテーション記号)で囲む必要がある。すなわち、Internet Explorer(C:\Program Files\Internet Explorer\iexplore.exe)を起動するには、
objWshShell.Run """C:\Program Files\Internet Explorer\iexplore.exe""" |
と書く必要がある。ちなみに、「"(ダブル・クォーテーション)」が3つ連続しているのは、"〜"の中では、" を記述するためには "" と重ねて記述しなければならないからである。
Runメソッドでは、実行ファイルに渡すオプションも指定可能だ。Internet Explorerをキオスク・モード(全画面表示)で起動するには「-k」オプションを付けるが、その場合は次のようになる。
objWshShell.Run """C:\Program Files\Internet Explorer\iexplore.exe"" -k" |
なお、キオスク・モードで開いたInternet Explorerのウィンドウは[Alt]+[F4]キーで閉じることができる。
Runメソッドはエクスプローラの関連付けに従ってファイルを開くこともできる。例えば、スクリプトが存在するフォルダにある「test.txt」というファイルを開くには、
objWshShell.Run "test.txt" |
のようにする。すると.txtファイルに関連付けされたエディタ(デフォルトではメモ帳)が起動し、test.txtを読み込んで表示する。
Runメソッドには前述のとおり、実行するアプリケーションのウィンドウ・スタイルを省略可能な第2引数に指定できる。例えば、
objWshShell.Run "notepad.exe",3 |
のように記述すると、メモ帳が最大化されて実行される。第2引数に指定できる数値は次の表のとおりである。なお、ウィンドウをアクティブにするかどうかも決定できる。
| 第2引数に与える数値 | ウィンドウ・スタイル | アクティブ・ウィンドウ |
| 0 | 非表示 | そのまま(変わらない) |
| 1(省略時の値) | 通常サイズ | 起動したアプリケーション |
| 2 | 最小化 | 起動したアプリケーション |
| 3 | 最大化 | 起動したアプリケーション |
| 4 | 通常サイズ | そのまま(変わらない) |
| 5 | そのまま | 起動したアプリケーション |
| 7 | 最小化 | そのまま(変わらない) |
| Runメソッドの第2引数 | ||
| Runメソッドの第2引数の数値を変更すると、実行するアプリケーションのウィンドウ・スタイルを指定できる。ほかにも第2引数に与える数値は10まで定義されているのだが、筆者の環境では有意な差が認められなかったのでここでは省略している。 | ||
Runメソッドには、アプリケーションの終了を待つか否かを決めるために、Boolean値を取る省略可能な第3引数も存在する。省略時はFalseで、アプリケーションの終了を待たずにRunメソッドの次の行が実行される(非同期処理)。Trueを指定すると、アプリケーションが終了するまでスクリプトが待機する(同期処理)。例えば次のように記述する。
objWshShell.Run "notepad.exe",,True |
この場合、メモ帳のウィンドウが立ち上がり、ユーザーがウィンドウを閉じると、(「メモ帳を起動しました。」という)メッセージ・ボックスが表示される。
なお、Runメソッドは終了コードを戻り値として返す(正常終了時は0)。
| INDEX | ||
| [基礎解説]チェック式 WSH入門 | ||
| 第12回 WshShellオブジェクトを利用する(1) | ||
| 1.Runメソッド | ||
| 2.AppActivateとSendKeysメソッド | ||
| 基礎解説 |
TechTargetジャパン
- WebサーバのSSL証明書が「正しい」か確認する (2012/2/10)
SSLに必要なサーバ証明書の取得/インストールのミスはWebサイトの信頼を失墜させかねない。証明書ベンダ提供のツールで手軽かつ確実にチェックしよう - クライアントでも利用可能になるHyper-V 3.0とは? (2012/2/9)
Windows 8では、従来のWindows Virtual PCに代わって新しくHyper-V 3.0がクライアント向けにも導入される。その概要を解説 - 第303話 ペアプロ2 (2012/2/7)
あっ、またまたいつぞやの幽霊が! …っと思ったら、何だ倉井さんかぁ…。はぁー、驚いた… - Excelで郵便番号変換ウィザードを活用する (2012/2/3)
Excelで管理している顧客名簿などで、不足している郵便番号や住所を入力するのは意外と面倒。郵便番号変換ウィザードを使えば、これらの入力が簡単になる
|
|
キャリアアップ
スポンサーからのお知らせ
- - PR -
イベントカレンダー
- - PR -




