
VBAとVBScriptを混同しているのかもしれませんがよく分からないので教えてください。
Excel2010のVBAから、外部プログラム(test.exe)をコマンドプロンプトを非表示の状態で実行して、外部プログラムの実行が終了するのを待ってから、次の処理をさせたいのですが、test1のプログラムでは(A)の部分でエラーになってしまいます。また、test2のプログラムでは正しく実行されるのですがコマンドプロンプトのウインドウを非表示にする方法がよく分かりません。
test1のプログラムでエラーをでなくする方法、または、test2のプログラムでコマンドプロンプトのウインドウを非表示にする方法がありましたら教えてください。
-------------------------------------------------------
Sub test1()
Dim ws As Object
Dim we As Object
Dim command As String
command = "C:\test.exe"
Set ws = CreateObject("WScript.Shell")
Set we = ws.Run("%ComSpec% /c " & command, 0, False) '<===(A)
Set we = Nothing
Set ws = Nothing
End Sub
-------------------------------------------------------
Sub test2()
Dim ws As Object
Dim we As Object
Dim command As String
command = "C:\test.exe"
Set ws = CreateObject("WScript.Shell")
Set we = ws.exec("%ComSpec% /c " & command)
Do Until we.Status
DoEvents
Loop
Set we = Nothing
Set ws = Nothing
End Sub
-------------------------------------------------------
No.2ベストアンサー
- 回答日時:
Runメソッドを何処で調べましたか?
詳しくはこちらを見てください。
http://msdn.microsoft.com/ja-jp/library/cc364421 …
先ず、Aで失敗する理由ですが、Runメソッドの戻り値は何型ですか?
説明を見れば分かると思いますが、整数です。オブジェクトでは
ありません。従って、戻り値の型が違うし、Set文を使うのもオカシイ
次に、プログラムの終了を待つなら、Runメソッドの第3引数は
省略するか、Trueを指定すべきです。
test2のExecメソッドはオブジェクトを返しますが、この中には
標準入出力やエラー出力用の出し入れ口があり、人に代わって
データを送り込んだり、出力結果を見て、処理を変更するなどを
行う場合に使いますので、今回の仕様では使いません。
尚、DoEventsでグルグル回る処理は絶対にすべきではありません。
必ずSleepを入れるべきだし、DoEventsの使用そのものを避ける
べきだからです。この文がどのような効果をもたらすかを理解しており、
それを制御できるだけの技術があれば別ですが・・・
教えて頂きました間違いの箇所を修正しましたらコンドプロンプトのウインドウが非表示のままで正しく実行することができました。ありがとうございました。
なお、回答の中で、「DoEventsでグルグル回る処理は絶対にすべきではありません。必ずSleepを入れるべきだし、DoEventsの使用そのものを避けるべきだからです。」ということが書かれていて、なぜなのかがよく分かりませんでしたので、いろいろ調べていましたが結局よく分かりませんでした。ネット上でもこのような処理をしているのをよく見かけるのですが(http://officetanaka.net/excel/vba/tips/tips27.htmなど)、どのような問題が起こり得るのでよろしくないのかがよく分からないので教えて頂けないでしょうか。よろしくお願いします。
No.3
- 回答日時:
#2です。
DoEvents文を実行すると、溜まっていた各種イベントが実行されます。
これに伴い、イベントプロシージャ(VBA)が実行されたり、セルの
内容が変化することもあります。極端な例ではプロセスの終了も
起こり得ます。本来の処理が中途で終わってしまったり、実行条件の
共通変数の内容が変化する可能性があります。このような事象が発生
することを承知の上で使うなら良いのです。
「何でDoEventsがいけないの?」と質問されるということはこの辺の
事情をご存じないのではないでしょうか?
故に「勧めない」と申し上げたのです。
尚、Sleepを入れないと、CPUタイムスライスを浪費して全体の
パフォーマンスに甚大な悪影響が出ます。
SleepはVBAではDeclarationsで以下のように定義します。
Declare Sub Sleep Lib "kernel32" (ByVal 休止時間 As Long)
【使用例】
Do Until we.Status
DoEvents
Sleep 1 '1ミリ秒休止
Loop
Sleepを入れないと、CPU使用率は100%近くになるはずです。
Sleepを入れると、CPU使用率はほぼ0です。
尚、Runメソッドで待機をTrueにすれば、上記の問題は起きません。
DoEventsだけだと少なくとも60%以上には上がっていましたがSleep 1を入れるとほぼ0%に下がっていました。このあたりのことはVBAの書籍ではあまり触れられていないのでとても参考になりました。
これからはSleep 1を入れるようにします。
ありがとうございました。
No.1
- 回答日時:
良く分かってないので勘違いがあるかもしれないけど。
test.exeはGUIアプリ? それともコンソールアプリ?
GUIアプリならRunに "%ComSpec% /c " は不要で、それで上手くいくかも。
コンソールアプリなら完全に非表示にするのは多分無理なのでウィンドウを7(最小化)にしてみる。
実行したいのはコンソールアプリの方です。
nda23さんの回答の対策をしましたらコマンドプロンプトのウインドウが非表示のまま実行できました。
また、ウィンドウを7(最小化)でも確認してみましたら、タスクバーにアイコンは表示されますが、コマンドプロンプトのウインドウは非表示で実行できました。
ありがとうございした。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) ExcelVBAに関する質問 3 2023/02/17 10:47
- Visual Basic(VBA) Excel vbaについての質問 3 2023/04/18 16:14
- Excel(エクセル) Excel-VBAの「しばらくお待ちください」のダイアログが自動的に閉じない 2 2023/05/24 15:31
- Visual Basic(VBA) batからexeを実行し戻り値を受け取る バッチからEXEの結果を受け取りたいのですが、 下記のバッ 1 2023/07/04 15:13
- Visual Basic(VBA) VBAが止まります。 2 2022/09/02 14:02
- Visual Basic(VBA) エクセルVBAのコードで質問です。 下のコードはJ16の文字列をB3を起点とする範囲から探して、見つ 5 2023/04/07 11:07
- Visual Basic(VBA) 【ご教示ください】VBAの記述方法がわかりません。 2 2022/08/12 21:28
- Visual Basic(VBA) batからexeを実行し戻り値を受け取る EXEの実行内容の結果によって、戻り値を0か1かで返したい 1 2023/07/04 16:40
- Visual Basic(VBA) 【VBAエラー】Nextに対するForがありません 対策について 5 2022/11/21 21:26
- Visual Basic(VBA) excel vbaでvlooupの変数がわかりません。 7 2022/05/30 09:35
このQ&Aを見た人はこんなQ&Aも見ています
-
excel vbaから実行するexe実行の黒い画面の非表示
Visual Basic(VBA)
-
VBAのExecメソッドで画面を非表示にして実行する方法
Visual Basic(VBA)
-
コマンドプロンプト実行後に画面を閉じない方法
Visual Basic(VBA)
-
-
4
VBAでブックを非表示で開いて処理して閉じる方法
Excel(エクセル)
-
5
VBAでエクセルシートを更新(リフレッシュ)する方法を教えて下さい。
Excel(エクセル)
-
6
コマンドプロンプトを最小化してバッチを実行したい
その他(プログラミング・Web制作)
-
7
TERA TERMを隠す方法
その他(プログラミング・Web制作)
-
8
他のアプリケーションの終了処理
Visual Basic(VBA)
-
9
VBAのコマンドボタンの文字列の改行方法は?
Visual Basic(VBA)
-
10
VBAでループ内で使う変数名を可変にできないか。
Visual Basic(VBA)
-
11
VBAにてメッセージボックスを最前面に表示させる
その他(プログラミング・Web制作)
-
12
ExcelVBAにてアプリをタスクマネージャーから強制終了させたいのですが
Visual Basic(VBA)
-
13
コマンドプロンプトでのPDFファイルの結合
その他(コンピューター・テクノロジー)
-
14
VBAでコマンドプロンプトをアクティブにしない
Visual Basic(VBA)
-
15
VBプログラムから「管理者として実行」したい
Visual Basic(VBA)
-
16
メッセージボックスを前面に表示させるには?
Visual Basic(VBA)
-
17
VBS実行時にコマンドプロンプトが表示される
その他(プログラミング・Web制作)
-
18
vbaから他のアプリを終了
Visual Basic(VBA)
-
19
VBA 変数名に変数を使用したい。
Visual Basic(VBA)
-
20
VBA コードを実行すると画面が真っ白になる
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Macターミナルで実行中のプログ...
-
VBAで一度開いたIEで再操...
-
プログラムの実行がうまくいか...
-
実行時エラー429
-
MO上でプログラムを実行?
-
パソコンの演算速度について
-
ラズパイ プログラム 自動起動 ...
-
NORTiプログラムのROM化
-
実行時にVBのモジュールファイ...
-
言語について
-
FORTRANについて
-
バッチの外部コマンド実行確認...
-
コマンドプロンプト プログラム...
-
C言語 コマンドラインの文字列...
-
apacheのコマンドプロンプトか...
-
プリントスクリーンをプログラ...
-
他の実行ファイルを実行するプ...
-
コマンドプロンプトでプログラ...
-
exeファイルが開かないのはなぜ...
-
Borland C++Builder6で、デバッ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Macターミナルで実行中のプログ...
-
パソコンの演算速度について
-
VB上で実行中の無限ループの止め方
-
sendkeysにてALT+CTRL+INSERTを...
-
C言語で途中までしか、プログラ...
-
VBAで外部プログラムを非表示で...
-
システム資源とは?
-
実行時エラー429
-
終了してもプログラムが実行し...
-
sleep()関数について
-
他の実行ファイルを実行するプ...
-
RPG パラメーターについて
-
UWSCがうまく動かない
-
Windows10でDOSゲーム
-
clock関数は正確じゃないの?
-
C言語でプログラムを再起動
-
Excel VBA から外部プログラム...
-
system関数を使用してsuコマン...
-
プロセス間通信について
-
Borland C++を利用しているので...
おすすめ情報