前提
サブフォルダの画像をシートに出力するマクロを組んでいる。
FSOを使った記述の仕方がわからない。
実現したいこと
-
Test配下にあるそれぞれのサブフォルダ内の画像をすべてシートに貼り付けたい。 -
貼り付けの際はサブフォルダごとの名前(Doubutu,Hito,Tabemono)で新規シートを作成し貼り付けられるようにしたい。
-
画像が入っているパスは以下の通り。Testの下にDoubutu,Hito,Tabemonoのフォルダがあり、その中に画像ファイルがそれぞれ3枚ずつ入っている。
発生している問題・エラーメッセージ
-
FSOを使った記述の仕方がわからない。 -
調べながら同じように記述するが実行できなくなってしまう。 - サブフォルダの名前で新規シートを作るという記述の組み込み方がわからない。
- 再帰的な処理について流れがわからない。
該当のソースコード
vba
1Sub PicInsert() 2 3 Dim FolderPath As String 4 FolderPath = Range("A2").Value 'A2には\Sampleまでのパスが入っている 5 Call FileSearch(FolderPath) 6 7End Sub 8 9 10Sub FileSearch(FolderPath As String) 11 12 Dim FSO As Object, Folder As Variant 13 Dim ws As Worksheet 14 15 Set FSO = CreateObject("Scripting.FileSystemObject") 16 17 For Each Folder In FSO.GetFolder(FolderPath).SubFolders 18 Call FileSearch(Folder.Path) 19 Next Folder 20 21 For Each File In FSO.GetFolder(FolderPath).Files 22 'Debug.Print File.Path 23 ActiveSheet.Pictures.Insert File.Path 24 Next File 25 26 '貼り付け方の指定プロシージャ 27 Call Paste 28 29End Sub
vba
1Sub Paste() 2 3 Dim Pic As Variant 4 Range("B3").Activate 5 For Each Pic In ActiveSheet.Shapes 6 Pic.Select 7 Pic.LockAspectRatio = msoTrue 8 9 Selection.ShapeRange.Top = ActiveCell.Top + 1 10 Selection.ShapeRange.Left = ActiveCell.Left 11 12 Pic.Height = 430 13 14 ActiveCell.Offset(25,0).Activate 15 Next Pic 16End Sub
試したこと
- サブフォルダのパスを指定してDebug.Printで出力させることはできた。
- サブフォルダのパスの指定やコードの記述の仕方については一通り調べた。
Paste()プロシージャのコードも質問に追加してください。
すみません。
追加いたしました。
回答を書いている間に質問を編集されたようですが、編集前のコードの方が目的に近いと思います。
サブフォルダーは1階層だけなので再帰は不要です。
とりあえず私の回答のコードの理解するようにしてください。
ご回答いただきありがとうございました。
セルに入れるパスをSampleまでにして再帰させる、シートを作成することが目的となったため変更しました。これから使っていくときにサブフォルダが何階層あるか不明な場合があると考えたためです。
根本で変更がありすみません。
ご回答いただいたコードをまずは理解できるように努め、その後ほかの疑問に取り組みます。
質問では、Test内にはサブフォルダーが3つ、それぞれにサブフォルダーには画像ファイルが3枚ということでしたが、サブフォルダーの中にさらにサブフォルダーがありそこに画像がある、というようにサブフォルダーの階層がどんどん深くなっていく可能性があるということですか。
だとしても、それは、まずは1階層だけの処理が完成してから取り組んだ方がいいかと思います。一度にいろいろしようとすると理解が追い付かないように思います。(提示されているコード見た感想ですが)
そうです。
Sampleから見た画像フォルダのように1階層にはならないフォルダを扱うかもしれないので、応用できるようになりたいということです。
そうですよね、おっしゃる通りだと思います。
取り組んでいて今やりたいことが自分のキャパをオーバーしていると感じています。
再帰しないフォルダパスの取得について取り組み、理解できてから次へ進みたいと思います。
助言いただきありがとうございました。
回答1件
あなたの回答
tips
プレビュー