次の方法で共有


CFileFind::IsDirectory

更新 : 2007 年 11 月

検索したファイルがディレクトリかどうかを確認します。

BOOL IsDirectory( ) const;

戻り値

正常終了した場合は 0 以外を返します。それ以外の場合は 0 を返します。

解説

ディレクトリには FILE_ATTRIBUTE_DIRECTORY 属性が設定されています。このファイル属性は、WIN32_FIND_DATA 構造体で認識されます。

IsDirectory を呼び出す前に、少なくとも 1 回は FindNextFile を呼び出す必要があります。

ファイル属性の一覧については、MatchesMask メンバ関数の説明を参照してください。

使用例

このコードは、C:\ ドライブのすべてのディレクトリを再帰的に検索し、見つかったディレクトリ名を出力します。

void Recurse(LPCTSTR pstr)
{
   CFileFind finder;

   // build a string with wildcards
   CString strWildcard(pstr);
   strWildcard += _T("\\*.*");

   // start working for files
   BOOL bWorking = finder.FindFile(strWildcard);

   while (bWorking)
   {
      bWorking = finder.FindNextFile();

      // skip . and .. files; otherwise, we'd
      // recur infinitely!

      if (finder.IsDots())
         continue;

      // if it's a directory, recursively search it

      if (finder.IsDirectory())
      {
         CString str = finder.GetFilePath();
         TRACE(_T("%s\n"), (LPCTSTR)str);
         Recurse(str);
      }
   }

   finder.Close();
}

void PrintDirs()
{
   Recurse(_T("C:"));
}

必要条件

ヘッダー : afx.h

参照

参照

CFileFind クラス

階層図

その他の技術情報

CFileFind のメンバ