
http://officetanaka.net/excel/vba/tips/tips95.htm
を参考に、
フォルダの一覧を取得するコードを作ってるのですが
Sample4ならエラーにならずにフォルダの一覧を取得できるのですが、
フォルダ名にドットがある場合も取得されてしまうので、Sample6を使いたいのですが、
If GetAttr(buf) And vbDirectory Then
の部分で、
「53ファイルが見つかりません。」
のエラーになります。
なぜでしょうか?
No.3ベストアンサー
- 回答日時:
参照ページのSample6を修正なくそのまま使ってる場合は
>「53ファイルが見つかりません。」
このエラーは出ないはずです。
例えば
Sub Sample6()
Dim buf As String, msg As String
buf = Dir("C:\TEST\*.*", vbDirectory)
Do While buf <> ""
If GetAttr(buf) And vbDirectory Then
If buf <> "." And buf <> ".." Then msg = msg & buf & vbCrLf
End If
buf = Dir()
Loop
MsgBox msg
End Sub
このようにDir関数で、カレントフォルダではなく、特定フォルダを指定するように修正してあると
ご提示のエラーになります。
変数bufにはDir関数の結果、ファイル名が入ります。
これに対して「GetAttr(buf)」この箇所を修正していないと、
ファイル名しか指定していない事になりますから、
カレントフォルダ&ファイル名になって、「53ファイルが見つかりません。」となります。
参照ページの冒頭に
>なお、カレントフォルダはC:\Workにしてあります。
とありますね。
フォルダ指定を省略してありますから、Dir関数もGetAttr関数もカレントフォルダ
つまり「C:\Work」に対する処理とみなされます。
修正するなら両方必要。
buf = Dir("C:\TEST\*.*", vbDirectory)
If GetAttr("C:\TEST\" & buf) And vbDirectory Then
ただ、対象フォルダにUnicode文字を使ったファイル名があると、
GetAttr関数のところで今度は「52 ファイル名または番号が不正です」のエラーになります。
直下のフォルダだけ取得するようなケースなら「FileSystemObject」を使ったほうが楽かもしれません。
Sub try()
Const p = "C:\TEST\"
Dim f As Object
Dim s As String
For Each f In CreateObject("scripting.filesystemobject").GetFolder(p).SubFolders
s = s & f.Name & vbLf
Next
MsgBox s
End Sub
No.2
- 回答日時:
No.1
- 回答日時:
こんにちは。
フォルダ内に、読み取り専用フォルダがあるとエラーがおきますので、
Sub Sample6()
Dim buf As String, msg As String
Dim zokusei As Integer, enzan As Integer
Dim Path_Str as String
Path_Str = "C:\Documents and Settings\" '最後のフォルダが読み取り専用フォルダの場合は、\をつけないとエラーがおきます
buf = Dir(Path_Str, vbDirectory + vbHidden) '←読み取り専用追加
Do While buf <> ""
zokusei = Getattr(Path_str & buf)
enzan = zokusei And 16
If enzan = 16 Then
If buf <> "." And buf <> ".." Then msg = msg & buf & vbCrLf
End If
buf = Dir()
Loop
MsgBox msg
End Sub
読み取り専用フォルダがあるとエラーになるのですか。
知りませんでした。
vbHiddenを追加したらうまく行きました。ありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
ファイル名と同名のフォルダを...
-
Excelのハイパーリンクについて...
-
フォルダAから1つのファイルだ...
-
Windows10でコマンドプロンプト...
-
デスクトップの画像をhtmlに表...
-
ExcelのVBAでフォルダ指定がで...
-
会社のネットワーク上のファイ...
-
【ExcelVBA】一覧表の記載に従...
-
EXCELのセルにフォルダのパスの...
-
パス名に2バイト文字(マルチバ...
-
C言語でのフォルダ作成
-
フォルダにリンクを貼りたい
-
エクセル マクロで指定フォル...
-
VBA 最新のフォルダ取得
-
多量のファイルをフォルダに自...
-
ファイル名に特定の文字列を含...
-
バッチファイルで指定フォルダ...
-
【マクロ】フォルダにファイル...
-
AIX findコマンド
-
ファイルとフォルダのどちらも...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Windows10でコマンドプロンプト...
-
VBA 最新のフォルダ取得
-
デスクトップの画像をhtmlに表...
-
ファイル名と同名のフォルダを...
-
会社のネットワーク上のファイ...
-
ExcelのVBAでフォルダ指定がで...
-
Excelで指定したフォルダに保存...
-
VBA フォルダの複数選択ができない
-
【マクロ】ファイル名の日付に...
-
VB.NRT FolderBrowserDialogを...
-
【マクロ】フォルダにファイル...
-
ThisWorkbookがあるフォルダ更...
-
ディレクトリ名変更してコピー...
-
(C#)フォルダを指定するダイ...
-
VB6で7-ZIPのAPIを使用した圧縮...
-
VBプロジェクトでのフォルダ構...
-
パス名に2バイト文字(マルチバ...
-
Debug フォルダは消していいの?
-
フォルダにリンクを貼りたい
-
フォルダAから1つのファイルだ...
おすすめ情報