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

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

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

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

マクロ

定義された処理手続きに応じて、どのような一連の処理を行うのかを特定させるルールをマクロと呼びます。

Q&A

解決済

1回答

791閲覧

サブフォルダ内の画像をサブフォルダ名のシートごとに貼り付けたい

kkkei

総合スコア2

VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

マクロ

定義された処理手続きに応じて、どのような一連の処理を行うのかを特定させるルールをマクロと呼びます。

0グッド

0クリップ

投稿2022/07/26 14:40

編集2022/07/27 02:38

前提

サブフォルダの画像をシートに出力するマクロを組んでいる。
FSOを使った記述の仕方がわからない。

実現したいこと

  • Test配下にあるそれぞれのサブフォルダ内の画像をすべてシートに貼り付けたい。

  • 貼り付けの際はサブフォルダごとの名前(Doubutu,Hito,Tabemono)で新規シートを作成し貼り付けられるようにしたい。

  • 画像が入っているパスは以下の通り。Testの下にDoubutu,Hito,Tabemonoのフォルダがあり、その中に画像ファイルがそれぞれ3枚ずつ入っている。

イメージ説明

・Doubutuフォルダーの中身
イメージ説明

発生している問題・エラーメッセージ

  • 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で出力させることはできた。
  • サブフォルダのパスの指定やコードの記述の仕方については一通り調べた。

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

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

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

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

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

hatena19

2022/07/27 01:14

Paste()プロシージャのコードも質問に追加してください。
kkkei

2022/07/27 02:39

すみません。 追加いたしました。
hatena19

2022/07/27 02:47

回答を書いている間に質問を編集されたようですが、編集前のコードの方が目的に近いと思います。 サブフォルダーは1階層だけなので再帰は不要です。 とりあえず私の回答のコードの理解するようにしてください。
kkkei

2022/07/27 03:02

ご回答いただきありがとうございました。 セルに入れるパスをSampleまでにして再帰させる、シートを作成することが目的となったため変更しました。これから使っていくときにサブフォルダが何階層あるか不明な場合があると考えたためです。 根本で変更がありすみません。 ご回答いただいたコードをまずは理解できるように努め、その後ほかの疑問に取り組みます。
hatena19

2022/07/27 03:13

質問では、Test内にはサブフォルダーが3つ、それぞれにサブフォルダーには画像ファイルが3枚ということでしたが、サブフォルダーの中にさらにサブフォルダーがありそこに画像がある、というようにサブフォルダーの階層がどんどん深くなっていく可能性があるということですか。 だとしても、それは、まずは1階層だけの処理が完成してから取り組んだ方がいいかと思います。一度にいろいろしようとすると理解が追い付かないように思います。(提示されているコード見た感想ですが)
kkkei

2022/07/27 03:45

そうです。 Sampleから見た画像フォルダのように1階層にはならないフォルダを扱うかもしれないので、応用できるようになりたいということです。 そうですよね、おっしゃる通りだと思います。 取り組んでいて今やりたいことが自分のキャパをオーバーしていると感じています。 再帰しないフォルダパスの取得について取り組み、理解できてから次へ進みたいと思います。 助言いただきありがとうございました。
guest

回答1

0

ベストアンサー

質問内容が多数ありますので、とりあえず下記の1点だけに絞って回答します。

FSOを使った記述の仕方がわからない。

いろいろ修正点がありますので、コメントで書くコードの意味を説明してあります。
自分のコードとの違いを確認してください。

vba

1Sub PicInsert() 2 '変数はVariant型ではなく適切な型で宣言した方がよい 3 Dim f As Object 4 Dim Path As String 5 Dim FileName As String 6 7 Path = Range("A1").Value 'セルにあらかじめTestまでのディレクトリを入れておく 8 9 With CreateObject("Scripting.FileSystemObject") 10 'サブフォルダーを順に取得 11 For Each f In .GetFolder(Path).SubFolders 'サブフォルダーオブジェクトを順に取得 12 FileName = Dir(f.Path & "\*.png") 'サブフォルダー内のpngファイル名を取得 13 Do Until FileName = "" '次のファイル名がなくなるまで繰り返す 14 15 'イミディエイトウィンドウにファイルパスを出力 16 Debug.Print f.Path & "\" & FileName 17 18 FileName = Dir() '次のファイル名を取得 19 Loop 20 Next f 21 End With 22 23End Sub

実行してみて、イミディエイトウィンドウに目的のファイル名が出力されているのを確認ください。
コードを意味を理解してください。

上記ができたら、サブフォルダー名でシートの追加、シートへの画像の挿入の処理を追加します。
下記のリンク先が参考になるでしょう。

VBA シートを追加する

エクセルVBAで大量の画像をまとめてシートに貼り付けるAddPictureメソッドの使い方


上記のコードに、下記の処理を追加する参考コードです。

  • サブフォルダー名で新規シートの追加、追加先は末尾
  • 追加したシートにサブフォルダー内のpng画像を挿入

vba

1Sub PicInsert() 2 '変数はVariant型ではなく適切な型で宣言した方がよい 3 Dim f As Object 4 Dim Path As String 5 Dim FileName As String 6 Dim newWorkSheet As Worksheet 7 Dim targertCell As Range 8 9 Path = Range("A1").Value 'セルにあらかじめTestまでのディレクトリを入れておく 10 11 With CreateObject("Scripting.FileSystemObject") 12 'サブフォルダーを順に取得 13 For Each f In .GetFolder(Path).SubFolders 'サブフォルダーオブジェクトを順に取得 14 15 '新規シートを末尾に追加して名前をフォルダー名に 16 Set newWorkSheet = Worksheets.Add(After:=Worksheets(Worksheets.Count)) 17 newWorkSheet.Name = f.Name 18 Set targertCell = newWorkSheet.Range("A1") '画像挿入セル 19 20 FileName = Dir(f.Path & "\*.png") 'サブフォルダー内のpngファイル名を取得 21 Do Until FileName = "" '次のファイル名がなくなるまで繰り返す 22 23 AddPicture f.Path & "\" & FileName, targertCell 24 Set targertCell = targertCell.Offset(25, 0) '画像挿入セルを25行下へ移動 25 26 FileName = Dir() '次のファイル名を取得 27 Loop 28 Next f 29 End With 30 31End Sub 32 33'画像挿入サブルーチン 34Sub AddPicture(ImgFileName As String, targertCell As Range) 35 targertCell.Parent.Shapes.AddPicture _ 36 FileName:=ImgFileName, _ 37 LinkToFile:=False, _ 38 SaveWithDocument:=True, _ 39 Left:=targertCell.Left, _ 40 Top:=targertCell.Top, _ 41 Width:=-1, _ 42 Height:=-1 43End Sub

投稿2022/07/27 02:40

編集2022/07/27 07:15
hatena19

総合スコア33715

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

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

kkkei

2022/07/28 00:53

ご回答ありがとうございます。 こちらのコードを試してみたところ複数のエラーが発生して実行されないのですが、自身の環境のせいでしょうか? サブフォルダ名でのシート追加の記述の仕方は大変参考になりました。ありがとうございます。
hatena19

2022/07/28 01:15

まず最初の方のコードで画像ファイル名がイミディエイトウィンドウに出力されるのは確認できたのでしょうか。それとも、これセエラーが出て実行できないのでしょうか。 また、エラーが出るなら、どの行でどのようなエラーが出るか教えてください。 どちらのコードもこちらのサンプルで動作確認済みです。
kkkei

2022/07/28 08:38

お返事ありがとうございます。 イミディエイトウィンドウに画像ファイル名が出力されること、エラーが出ずに実行できることが確認できました。 原因はAddPictureの引数が7つきちんと書かれていなかったこと、書き方が間違っていたことでした。 修正してくださっていたことに気付かず、ソースを変えず実行していました。すみません。 ご回答ありがとうございました。 このソースを理解して、それをもとにほかにも処理を加えて応用に使わせていただきます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問