前提・実現したいこと
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/ツールのバージョンなど) ここにより詳細な情報を記載してください。
エラーとコードはコードブロック ```~~~```はわけてください。コードブロックに入っていないコードがありますので、いずれもコードブロックに入れてください。
回答4件
あなたの回答
tips
プレビュー