data:image/s3,"s3://crabby-images/8b4aa/8b4aa999d801fa45f105bd7a2507596a0106b08c" alt=""
VBAから
Power Shellのコマンドレットを実行して…
data:image/s3,"s3://crabby-images/e9b50/e9b506ecc1bf3b04b41da90d14df7b6ef683dd23" alt="Power Shellのコマンドレットの実行結果"
data:image/s3,"s3://crabby-images/8b4aa/8b4aa999d801fa45f105bd7a2507596a0106b08c" alt=""
その結果を
VBAで取得できます!
data:image/s3,"s3://crabby-images/d0ca1/d0ca1c2e0248d42eea318d9688a6a366743badf3" alt="Power Shellのコマンドレットの実行結果を取得"
VBAコード
ここでは例として、
・コマンドレット「(Invoke-WebRequest -Uri ‘https://www.yahoo.co.jp/’).StatusCode」を実行して
・結果を取得
します。
※上記のコマンドレットは「指定したURLのHTTPステータスコードを取得するコマンドレット」です。
※例として「YahooのHTTPステータスコードを取得」します。
'変数の宣言を必須
Option Explicit
Sub sample()
Const START_ROW As Long = 2
Dim psCommand As String
Dim wsh As Object
Dim execObj As Object
Dim psCommandResult As String
'実行するPower Shellのコマンドレットを指定
psCommand = "(Invoke-WebRequest -Uri 'https://www.yahoo.co.jp/').StatusCode"
Set wsh = CreateObject("WScript.Shell")
'Power Shellのコマンドレットを実行
Set execObj = wsh.exec("powershell -NoProfile -ExecutionPolicy Unrestricted " & psCommand)
'Power Shellのコマンドレットの実行結果を取得
psCommandResult = execObj.stdOut.ReadAll
'Power Shellのコマンドレットの実行結果を表示
MsgBox psCommandResult
'後片付け
Set execObj = Nothing
Set wsh = Nothing
End Sub
実行結果
Power Shellの実行結果を取得できました。
data:image/s3,"s3://crabby-images/d0ca1/d0ca1c2e0248d42eea318d9688a6a366743badf3" alt="実行結果"
参考①
「Power Shellファイルを実行」することもできます。
詳細は以下の記事をご確認ください。
参考②
上記のVBAコードで使用した以下の詳細は、公式サイトをご確認ください。
●「WScript.Shell」の「exec」メソッド
●「WScript.Shell」の「stdOut」プロパティ
●Invoke-WebRequestコマンドレット
参考③
HTTPステータスコードの詳細は、以下をご確認ください。