
Excel VBA初心者です。
Excelのセルに記入されている文字列をコマンドプロンプトで実行する方法を教えて下さい。
具体的には、
A1 → d:
A2 → cd hogehoge
A3 → dir
とセルにそれぞれ記入されていたとして、フォームから作成したボタンを押下すると
A1~A3が順番にコマンドプロンプトで実行(貼り付け)されるマクロの作り方が知りたいです。
ロジックは以下のようにしたいと考えています。
セルA1に値 →ない→ 「値がありません」というエラーのポップアップか何かを表示。
↓ある
セルA1に記入された文字列をコマンドプロンプトで実行
↓
セルA2に値 →ない→exit
↓ある
セルA2に記入された文字列をコマンドプロンプトで実行
↓
セルA3に値 →ない→exit
↓ある
以下ループ
わかりにくいかもしれませんが、よろしくお願い致します。
No.2ベストアンサー
- 回答日時:
目的が分からないのですが、思いつきで作成してみました。
セルの情報からバッチファイルを生成して実行するコードです。
XPSP3、XL2000で試しています。ご参考まで。
Sub test()
Dim targetRange As Range
Dim FSO As Object
Dim i As Long
Dim myTextFile As Object
Dim batFilePath As String
Set FSO = CreateObject("Scripting.FileSystemObject")
’バッチファイルをテンポラリフォルダーに作成して実行します
batFilePath = FSO.GetSpecialFolder(2) & "\temp.bat"
Set myTextFile = FSO.CreateTextFile(batFilePath)
With ActiveSheet
Set targetRange = .Range(.Range("A1"), .Range("A" & .Rows.Count).End(xlUp))
End With
With myTextFile
For i = 1 To targetRange.Cells.Count
If i = targetRange.Cells.Count Then
'コマンドプロンプトを開いたままにする
.writeline "cmd /k " & targetRange.Cells(i)
Else
.writeline targetRange.Cells(i)
End If
Next i
.Close
End With
Set FSO = Nothing
CreateObject("WScript.Shell").Run "CMD.EXE /C " & batFilePath, , True
End Sub
おまけで、DOSコマンドの実行結果をVBAで取得したい時は、下記が参考になると思います。
http://www.f3.dion.ne.jp/~element/msaccess/AcTip …
No.1
- 回答日時:
初心者がやるような課題ではない。
したければ自分で勉強のこと。いまさら何でこういうことが必要なのか疑問?質問者は20年前のコンピュター従事者のの残党ですか。
したいことを方法論を指定せずに、別に質問したら(VBA、VBscriptなどで出来る範囲ということで)
http://oshiete.goo.ne.jp/qa/4276876.html の#2のWendy02さんより
>それをバッチプログラムでっていうのは、私には良く分からないです。もう、WScript でも古いというのに、なお古い方法を選ぶのは、ちょっともう世界が違うように思います。
ーー
Googleで「vba dos コマンド 実行」で照会すると、沢山記事が出る。ただし、DOSコマンドに習熟していないと読んでもわかりにくいと思うが。
http://officetanaka.net/excel/vba/tips/tips27.htm ほか多数
上記を元に cd を実行して、dirを実行する例をやってみた。上記の解説のスイッチの意味など十分わかってないが(生煮えですまないが)参考までに挙げておく。
I1:I2に
dir
C:\Documents and Settings\XXXX\My Documents (最後に¥は不要のようだ)
が入っている。
ーーー
標準モジュールに
Sub Sample2()
Dim WSH, wExec, sCmd As String, Result As String, tmp, i As Long
Set WSH = CreateObject("WScript.Shell")
sCmd = "cd " & Cells(2, "I")
'--cd XXX
Set wExec = WSH.Exec("%ComSpec% /c " & sCmd)
Do While wExec.Status = 0
DoEvents
Loop
'--Dir
sCmd = "dir"
Set wExec = WSH.Exec("%ComSpec% /c " & sCmd)
Do While wExec.Status = 0
DoEvents
Loop
Result = wExec.StdOut.ReadAll
tmp = Split(Result, vbCrLf)
For i = 0 To UBound(tmp)
Cells(i + 1, 1) = tmp(i)
Next i
Set wExec = Nothing
Set WSH = Nothing
End Sub
ーー
ただし
Dos窓を閉じるとセルにファイル名などが出てきた。
StdOutの文字数制限のためか、途中までしか出ない。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
コマンドプロンプトのエラーに...
-
「win11-23H2」を「win11-24H2...
-
[teraterm] waitコマンドで停止...
-
VBscriptが起動しない?
-
「読み取りと実行」と「読み取...
-
VBAを時間指定で自動実行
-
Excel VBA ステップインが途中...
-
エクセル フォルダの画像を画...
-
COBOLのイニシャライズとバリュ...
-
バッチファイルで以下のような...
-
【VB.NET】exeを実行すると「発...
-
NASに移したBATファイルからセ...
-
バッチファイルが不正終了して...
-
WSH.Run の処理内容をテキスト...
-
三菱ラダーについて教えて下さい。
-
PDFファイルを開き、印刷し、閉...
-
Access の VBA 実行中に他の操...
-
シェルからCで作った実行ファイ...
-
exeファイルを実行するとコマン...
-
ネットワーク名が見つかりません
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
コマンドプロンプトのエラーに...
-
「win11-23H2」を「win11-24H2...
-
[teraterm] waitコマンドで停止...
-
「読み取りと実行」と「読み取...
-
これってパソコンの最適化が完...
-
バッチファイルの内容を表示さ...
-
exeファイルを実行するとコマン...
-
複数のbatファイルを自動実行し...
-
VBscriptが起動しない?
-
ExcelのVBAが特定のPC上でのみ...
-
Excel(エクセル) VBA プロシー...
-
Windows System32 Security Hea...
-
PDFファイルを開き、印刷し、閉...
-
VBScriptでコマンドプロンプト...
-
batからexeを実行し戻り値を受...
-
Access の VBA 実行中に他の操...
-
Excel VBA ステップインが途中...
-
【VB.NET】exeを実行すると「発...
-
バッチファイルが不正終了して...
-
VBA 既に開いているBookに継続...
おすすめ情報