質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
VBScript

VBScript(Visual Basic Scripting Edition)はMicrosftが開発したスクリプト言語であり、Visual Basicのサブセットです。

Q&A

解決済

1回答

3875閲覧

カレントにあるフォルダとサブフォルダを別のドライブにコピーしたい

TAHA

総合スコア16

VBScript

VBScript(Visual Basic Scripting Edition)はMicrosftが開発したスクリプト言語であり、Visual Basicのサブセットです。

0グッド

0クリップ

投稿2017/10/18 02:09

###前提・実現したいこと
vbscriptでカレントにあるフォルダとサブフォルダをR:\MISにコピーするプログラムを作成しました。定期的に実行し、R:\MISにないフォルダがあればコピーします。

###発生している問題・エラーメッセージ
サブフォルダがうまくコピーできていないため、MsgBox objFolder.SubFolders.Countでフォルダ数をみると、カレントのフォルダ分しかカウントされていませんでした。配下には1000以上のサブフォルダを網羅できていないため、その原因を特定したいです。

エラーメッセージ 特にないが、サブフォルダ数がカウントされない。 ###該当のソースコード '■自分のいる階層のディレクトリ構成をコピーする■ '下位の階層もコピーする(再帰処理) set objFS = CreateObject("Scripting.FileSystemObject") '親フォルダ名(階層なし)を特定 Dim PtFdr PtFdr = objFS.GetFilename (objFS.GetAbsolutePathName(".")) '各フォルダ名を取得する set objFolder = objFS.GetFolder(".") '子フォルダの作成 Call MkSameDir("R:\MIS\",".") '//Function ////////////////////////////////////////// '■子フォルダに階層内のフォルダを保存 Private Sub MkSameDir(SvFdr,BaseDir) 'パラメータ(作成先Dir,コピー元Dir) Dim objFSO ' FileSystemObject Set objFSO = WScript.CreateObject("Scripting.FileSystemObject") 'フォルダ存在チェック set objFolder = objFS.GetFolder(BaseDir) set objSF = objFolder.SubFolders if objSF.count = 0 then 'フォルダがなければ終了(再帰終了条件) MsgBox("フォルダがありません。。") WScript.Quit(1) End If MsgBox objFolder.SubFolders.Count WScript.Quit(1) For Each objFC in objFolder.Subfolders '最初の階層で作ったフォルダ(自分自身)は、フォルダとして数えない If objFC.name = objFS.GetFileName(SvFdr) and BaseDir = "." then Else If objFSO.FolderExists(SvFdr & "\" & objFC.name) = False Then objFS.CreateFolder(SvFdr & "\" & objFC.name) Call MkSameDir(SvFdr & "\" & objFC.name , BaseDir & "\" & objFC.name) End if End if Next Set objFSO = Nothing End Sub ###試したこと if関数でカレントにフォルダがない場合は、msgboxでメッセージを出すようにした。特にメッセージは出ていない。 MsgBox objFolder.SubFolders.Countで、フォルダ数を確認したところ、カレントのフォルダ分しかカウントされず、サブフォルダを含んでいない。 下記をコメント明日とすれば、for each構文でカレントからR:MISのコピーが開始されるが、サブフォルダはコピーqされない。。 MsgBox objFolder.SubFolders.Count WScript.Quit(1) ###補足情報(言語/FW/ツール等のバージョンなど)

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

良くは見ていませんが、定期的に動作させるということは、既に存在するディレクトリもあるはずです。
現状の作りですと、再帰呼び出しされるのはコピー先にディレクトリが存在しないときのみなので、既にある場合は再帰されていないように見えます。
試しに再帰で呼び出すところを次のようにしてみてはいかがでしょうか。

VBA

1If objFSO.FolderExists(SvFdr & "\" & objFC.name) = False Then 2 objFS.CreateFolder(SvFdr & "\" & objFC.name) 3End if 4’ ↓この処理をIf文の外に出す 5Call MkSameDir(SvFdr & "\" & objFC.name , BaseDir & "\" & objFC.name) 6

投稿2017/10/18 04:20

ttyp03

総合スコア16998

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問