data:image/s3,"s3://crabby-images/8b4aa/8b4aa999d801fa45f105bd7a2507596a0106b08c" alt=""
VBAから
コマンドプロンプトのコマンドを実行して…
data:image/s3,"s3://crabby-images/9d4ec/9d4ecd11a43e9756adcb81bb0cdb54c34c57c9fd" alt="コマンドプロンプト(pingコマンド)の実行結果"
data:image/s3,"s3://crabby-images/8b4aa/8b4aa999d801fa45f105bd7a2507596a0106b08c" alt=""
その結果を
VBAで取得できます!
data:image/s3,"s3://crabby-images/02153/021535ea2057e287cd33a7e4e11a44e7f8e17519" alt="コマンドプロンプト(pingコマンド)の実行結果を取得"
VBAコード
ここでは例として、
・コマンド「ping 192.168.10.1」を実行して
・結果を取得
します。
※「pingコマンド」は「ネットワークの疎通確認をするコマンド」です。
'変数の宣言を必須
Option Explicit
Sub sample()
Dim command As String
Dim wsh As Object
Dim execObj As Object
Dim commandResult As String
'実行するコマンドを指定
command = "ping 192.168.10.1"
Set wsh = CreateObject("WScript.Shell")
'コマンドを実行
Set execObj = wsh.exec("%ComSpec% /c " & command)
'コマンドの実行結果を取得
commandResult = execObj.stdOut.ReadAll
'コマンドの実行結果を表示
MsgBox commandResult
'後片付け
Set execObj = Nothing
Set wsh = Nothing
End Sub
実行結果
コマンドプロンプトの実行結果を取得できました。
data:image/s3,"s3://crabby-images/02153/021535ea2057e287cd33a7e4e11a44e7f8e17519" alt="実行結果"
参考①
シンプルに「コマンドプロンプトのコマンドを実行」することもできます。
詳細は以下の記事をご確認ください。
参考②
上記のVBAコードで使用した以下の詳細は、公式サイトをご確認ください。
●「WScript.Shell」の「exec」メソッド
●「WScript.Shell」の「stdOut」プロパティ