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

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

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

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

Q&A

解決済

4回答

5370閲覧

VBA 再帰処理 FileSystemObject

kewashi

総合スコア8

VBA

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

0グッド

0クリップ

投稿2018/06/17 18:24

前提・実現したいこと

VBAのFileSystemObjectの使い方についての質問です。
以下のソースの様に指定したフォルダ内のファイルを全て読み取りたいのですが、
サブフォルダも含めてファイルを読み取りたいためFor EachでGetFolderメソッドを使用して
全てのフォルダ内のファイルを読み取っています。

ただ、ソース内のコメントの通りFor Each内でCallをする時の引数の指定で.Pathを付けなければ
エラーとなるのが分かりません。
For Eachの変数FolderNameではパスを受け取っているはずなのですが
Callするときになぜ.Pathを付けなければいけないのでしょうか。

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

エラーメッセージ ByRef 引数の型が一致しません ### 該当のソースコード Call test4(FolderName) ```ここに言語名を入力 ソースコード Sub test4(Path As String) Dim FSO As New Scripting.FileSystemObject Dim buf As String buf = Dir(Path & "*.*") Do While buf <> "" Debug.Print buf buf = Dir() Loop For Each FolderName In FSO.GetFolder(Path).SubFolders '←FolderNameが受け取っている要素はString型のはずですが         '以下の通りCall test4(FolderName) ではエラーとなります Call test4(FolderName) '←これだと「ByRef 引数の型が一致しません」エラーになります。 Call test4(FolderName.Path) '←.Pathを付ける必要があるのはなぜでしょうか。 Next End Sub Sub test() test4 ("C:\Users\ユーザ名\Desktop\test") End Sub ### 試したこと VarType()を使用してFolderNameをみてもどちらも(.Pathを付けても付けなくても)String型と出ます。 ### 補足情報(FW/ツールのバージョンなど) ここにより詳細な情報を記載してください。

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

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

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

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

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

m.ts10806

2018/06/18 00:09

エラーとコードはコードブロック ```~~~```はわけてください。コードブロックに入っていないコードがありますので、いずれもコードブロックに入れてください。
guest

回答4

0

ベストアンサー

SubFolders関数は下記サイトにあるようにFoldersコレクションを返します。
https://msdn.microsoft.com/ja-jp/library/cc428151.aspx

そしてFoldersコレクションは下記サイトにあるように、Folderオブジェクトのコレクションです。
https://msdn.microsoft.com/ja-jp/library/cc428003.aspx

つまりFor EachSubFolders関数を対象にすると、Folderオブジェクトをひとつずつ取得できるということになります。
なので、FolderNameに入るのはFolderオブジェクトです。String型ではありません。
https://msdn.microsoft.com/ja-jp/library/cc428096.aspx

投稿2018/06/18 00:17

ttyp03

総合スコア16998

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

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

kewashi

2018/06/18 09:03

丁寧な説明ありがとうございました。解決しました。
guest

0

https://msdn.microsoft.com/ja-jp/vba/language-reference-vba/articles/subfolders-property
「Folders コレクションを戻します」って書いてるのでStringじゃないと思いますよ。

投稿2018/06/17 18:53

shun-K

総合スコア508

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

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

0

補足です

VarType()を使用してFolderNameをみてもどちらも(.Pathを付けても付けなくても)String型と出ます。

の部分ですが、
varTypeはその変数の内部処理形式の型を返しますので変数自体の型はわかりません。テストされているコードの場合、FolderName(Folderオブジェクト)のデフォルト値(おそらく.nameか.path)を見てStringになっているもとの思われます。

変数自体の型を確認するときは、typeNameを使ってください。

投稿2018/06/18 00:51

h.horikoshi

総合スコア505

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

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

kewashi

2018/06/18 09:04

確認方法まで教えて頂きありがとうございます。
guest

0

For Each FolderName In FSO.GetFolder(Path).SubFolders '←FolderNameが受け取っている要素はString型のはずですが

↑メソッド名、プロパティ名がすべてを物語っている。

GetFolder ⇒フォルダ取得=フォルダ型。
SubFolders ⇒サブフォルダ=フォルダのコレクション型。

投稿2018/06/18 00:13

tkturbo

総合スコア5572

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問