VBA技術解説
Dir関数の制限について

ExcelマクロVBAの問題点と解決策、VBAの技術的解説
最終更新日:2016-03-16

Dir関数の制限について

VBAでフォルダ・ファイルの存在確認や、
一覧取得において使われる関数ですが、
いくつかの使用上の注意点、制限事項があります。


・3桁拡張子の指定時の問題
Sub Sample1()
  Dim buf As String
  buf = Dir(ThisWorkbook.Path & "\*.xls")
  Do While Len(buf) > 0
    '・・・処理・・・
    buf = Dir()
  Loop
End Sub
このように指定した場合、xlsxやxlsmも対象となります。

3桁の拡張子を指定した場合は、4桁の拡張子も対象となります。
つまり、
*.xls*
これと同じ動作という事です。

Dir関数を使って、3桁拡張子のファイルのみ取得するには、
Sub Sample2()
  Dim buf As String
  buf = Dir(ThisWorkbook.Path & "\*.xls")
  Do While Len(buf) > 0
    If LCase(buf) Like "*.xls" Then
      buf = buf
    End If
    buf = Dir()
  Loop
End Sub
If LCase(buf) Like "*.xls" Then
この部分は、

If Mid(buf, InStrRev(buf, ".") + 1) = "xls" Then
このような書き方でも良いでしょう。


・256バイトを超えるパス名が扱えない

これは、そもそもWindowsとしての制限もあるので、ローカルのPC内の処理では通常は問題が出ないはずです。

ネットワークドライブ等でこの問題が発生した時の回避方法としては、
ファイルシステムオブジェクト(FileSystemObject)を使ってください。
FileSystemObjectオブジェクトでは、コンピュータのファイルシステムへのアクセスが提供されています。VBAに用意されているファイル操作関連のステートメントや関数より、より強力で、より多くの機能が搭載されています。ただし、機能が大変多いため、これらを全て覚えるという事は困難です。


・特殊なネットワークドライブでエラー

ネットワークドライブで、
\\abc.def.ghi\
このような名称の場合は、
実行時エラー '52' ファイル名または番号が不正です。
このようなエラーになってしまいます。

最も簡単な回避方法は、
ネットワクドライブの割り当てをすることでしょう。
もしくは、
ファイルシステムオブジェクト(FileSystemObject)を使う事です。
FileSystemObjectオブジェクトでは、コンピュータのファイルシステムへのアクセスが提供されています。VBAに用意されているファイル操作関連のステートメントや関数より、より強力で、より多くの機能が搭載されています。ただし、機能が大変多いため、これらを全て覚えるという事は困難です。


全体としては、
ファイルシステムオブジェクト(FileSystemObject)を使う方が無難なのですが、

FileSystemObjectオブジェクトでは、コンピュータのファイルシステムへのアクセスが提供されています。VBAに用意されているファイル操作関連のステートメントや関数より、より強力で、より多くの機能が搭載されています。ただし、機能が大変多いため、これらを全て覚えるという事は困難です。
VBAからしたら、外部のオブジェクトを扱う訳ですから面倒ではあります。
出来れば、Dir関数で済ませられるようなPC環境にすることをお勧めします。



同じテーマ「マクロVBA技術解説」の記事

入力規則のドロップダウンが消えてしまうマクロ(Shapes内のDrop Down)
実行時にトラップ可能なエラー番号一覧
フォルダー・ファイル(ブック)・シートの文字制限
Excel2013におけるScreenUpdatingの問題点
Dir関数の制限について
よくあるVBA実行時エラーの解説と対応
Application.Goto使用時の注意
ScreenUpdating=False時にエラー停止後にシートが固まったら
標準スタイル違いの問題点:標準フォント複写、列幅をピクセルで合わせる
VBAでエラー行位置(行番号)を取得できるErl関数


新着記事NEW ・・・新着記事一覧を見る

VBAで写真の撮影日時や音楽動画の長さを取得する|VBA技術解説(1月10日)
ツイッターで出されたVBAのお題をやってみた|エクセル雑感(1月13日)
イベントプロシージャーの共通化(Enter,Exit)|ユーザーフォーム入門(1月13日)
Rangeオブジェクトの論理演算(差集合と排他的論理和)|VBA技術解説(1月10日)
イベントプロシージャーの共通化|ユーザーフォーム入門(1月7日)
コントロールの動的作成|ユーザーフォーム入門(1月6日)
Evaluateメソッド(文字列の数式を実行します)|VBA技術解説(1月5日)
エクスポート(PDF/XPS)|VBA入門(1月2日)
分析関数(OVER句,WINDOW句)|SQL入門(12月25日)
取得行数を限定するLIMIT句|SQL入門(12月21日)


アクセスランキング ・・・ ランキング一覧を見る

1.最終行の取得(End,Rows.Count)|VBA入門
2.RangeとCellsの使い方|VBA入門
3.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
4.マクロって何?VBAって何?|VBA入門
5.Range以外の指定方法(Cells,Rows,Columns)|VBA入門
6.変数宣言のDimとデータ型|VBA入門
7.繰り返し処理(For Next)|VBA入門
8.セルに文字を入れるとは(Range,Value)|VBA入門
9.空白セルを正しく判定する方法(IsEmpty,IsError,HasFormula)|VBA技術解説
10.徹底解説(VLOOKUP,MATCH,INDEX,OFFSET)|エクセル関数超技




このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。


記述には細心の注意をしたつもりですが、
間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
掲載のVBAコードは動作を保証するものではなく、あくまでVBA学習のサンプルとして掲載しています。
掲載のVBAコードは自己責任でご使用ください。万一データ破損等の損害が発生しても責任は負いません。



このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。
本文下部へ