Excel VBA質問箱 IV

当質問箱は、有志のボランティア精神のおかげで成り立っています。
問題が解決したら、必ずお礼をしましょうね。
本サイトの基本方針をまとめました。こちら をご一読ください。

投稿種別の選択が必要です。ご注意ください。
迷惑投稿防止のため、URLの入力を制限しています。ご了承ください。


33359 / 76734 ←次へ | 前へ→

【48597】Re:複数フォルダの全ファイル取得方法
回答  ハチ  - 07/4/24(火) 14:00 -

引用なし
パスワード
   ▼もとあし さん:
>>CmdTxt = """dir" & Dir_Opt & " " & """" & myPath & "\" & Target_File & """"""
>ここで、""がたくさんあるのが、どういう意味なのか、わかりません。が、
>もう少し記述の法則など調べてみます。

VBA上で、"を認識させるには、""とする必要があります。
結果を確認してみてください。
Sub Test1()
  Debug.Print """"
  Debug.Print """"""
End Sub


>>Set WSH = CreateObject("WScript.Shell")
>>Set Cmd = WSH.Exec("%ComSpec% /C " & CmdTxt)
>ここの%ComSpec% は環境変数というものですか?(%は何をしているのでしょうか?)

その通りです。コマンドラインで環境変数を使う場合は、%で括ります。
試しにコマンドプロンプトを開いて
set と入力してみてください。
その後、echo %変数名%(%OS%とか)
標準出力(表示)されるのがわかると思います。
このへんはDOSとかBATファイルとか勉強してみてください。

>それでC:\WINDOWS\system32\cmd.exeが起動されるようですが、
>コマンドプロンプトとは違うものですか?

同じです。Win9xでは、cmd.exeではなくてcommand.exeになりますので、
OS依存を避ける為にComSpecを使いました。

>また、これを表示しないようにする方法はありますか?

Execメソッドではできません。
Runメソッドならできますが、標準出力を直接取得することはできない為、
リダイレクトでテキストファイルに出力し、それを読み込むことできます。
(そこまでやるなら、別の方法でやるほうが良いと思いますが・・)
とりあえずTest2()を実行するとtxtファイルができます。
どこにできるかは、調べられるはずです^^

>なのでお忙しいところ申し訳ありませんが、もう少しお付き合いくださって、
>コードの解説をもしいただければ嬉しいです。
>よろしくお願いします。

Option Explicit

Sub Test()
Dim WSH As Object
Dim Cmd As Object
Dim CmdTxt As String
Dim myPath As String
Dim i As Long

Const Target_File As String = "*.xls"
Const Dir_Opt As String = "/S /B /A:-D" 'Dirオプションの指定(コマンドプロンプトで確認)

myPath = "e:Work" 'ルートパスの指定
CmdTxt = """dir" & Dir_Opt & " " & """" & myPath & "\" & Target_File & """"""

'修正
CmdTxt = "%ComSpec% /C " & CmdTxt
'確認用に追加。イミディエイトで確認
'これをコマンドプロンプトに貼り付けて実行すると、同じ結果が表示されるはず。
Debug.Print CmdTxt

'標準出力を取得するのにWScript.Shell.Exceを使用する。
Set WSH = CreateObject("WScript.Shell")
Set Cmd = WSH.Exec(CmdTxt)

i = 1
'実行結果の標準出力を一行づつ読み込んでセルに書き出し
Do Until Cmd.StdOut.AtEndOfStream
  Cells(i, 1).Value = Cmd.StdOut.ReadLine
  i = i + 1
Loop

Set Cmd = Nothing
Set WSH = Nothing

End Sub

Sub Test2()
Dim WSH As Object
Dim CmdTxt As String
Dim myPath As String
Dim i As Long

Const Target_File As String = "*.xls"
Const Dir_Opt As String = "/S /B /A:-D" 'Dirオプションの指定(コマンドプロンプトで確認)

myPath = "e:Work" 'ルートパスの指定
CmdTxt = """dir" & Dir_Opt & " " & """" & myPath & "\" & Target_File & """"""

'修正
CmdTxt = "%ComSpec% /C " & CmdTxt & " > %HOMEPATH%\TestDir.txt"
'確認用に追加。イミディエイトで確認
Debug.Print CmdTxt

Set WSH = CreateObject("WScript.Shell")
'Runメソッドに変更
WSH.Run CmdTxt, 0

Set WSH = Nothing

End Sub

7 hits

【48577】複数フォルダの全ファイル取得方法 もとあし 07/4/23(月) 15:48 質問
【48579】Re:複数フォルダの全ファイル取得方法 ハチ 07/4/23(月) 17:28 回答
【48595】Re:複数フォルダの全ファイル取得方法 もとあし 07/4/24(火) 11:50 お礼
【48597】Re:複数フォルダの全ファイル取得方法 ハチ 07/4/24(火) 14:00 回答
【48609】Re:複数フォルダの全ファイル取得方法 もとあし 07/4/25(水) 14:24 お礼
【48610】Re:複数フォルダの全ファイル取得方法 ハチ 07/4/25(水) 15:47 発言
【48613】Re:複数フォルダの全ファイル取得方法 もとあし 07/4/25(水) 16:08 お礼
【48581】Re:複数フォルダの全ファイル取得方法 ichinose 07/4/23(月) 18:42 発言
【48596】Re:複数フォルダの全ファイル取得方法 もとあし 07/4/24(火) 12:01 お礼
【48612】Re:複数フォルダの全ファイル取得方法 もとあし 07/4/25(水) 15:53 質問
【48618】Re:複数フォルダの全ファイル取得方法 ichinose 07/4/25(水) 19:52 発言
【48627】Re:複数フォルダの全ファイル取得方法 もとあし 07/4/26(木) 10:31 お礼
【48638】Re:複数フォルダの全ファイル取得方法 ichinose 07/4/26(木) 22:01 発言
【48639】Re:複数フォルダの全ファイル取得方法 追伸 ichinose 07/4/27(金) 7:32 発言
【48642】Re:複数フォルダの全ファイル取得方法 追伸 もとあし 07/4/27(金) 12:02 お礼

33359 / 76734 ←次へ | 前へ→
ページ:  ┃  記事番号:
2610219
(SS)C-BOARD v3.8 is Free