C++代码实现遍历文件夹及子文件夹

33 下载量 184 浏览量 更新于2024-08-29 收藏 209KB PDF 举报
本文主要介绍了在C++中遍历文件夹下所有文件的不同方法,强调了在使用相对路径时需要注意初始目录的设置,以及推荐在C/C++中处理单任务,利用脚本语言进行文件遍历。提供的代码示例中包含了一个名为`CBrowseDir`的类,该类提供了遍历目录和处理文件的功能。 在C++中遍历文件夹通常涉及到使用标准库中的`<dirent.h>`或`<filesystem>`(C++17以后)。`CBrowseDir`类是一个自定义的实现,它包括以下关键方法: 1. **CBrowseDir()**: 缺省构造器,初始化成员变量`m_szInitDir`,用于存储初始目录的绝对路径。 2. **SetInitDir(const char* dir)**: 设置初始目录。如果传入的目录无效,函数返回`false`。 3. **BeginBrowse(const char* filespec)**: 开始遍历初始目录及其子目录下符合`filespec`规则的文件。`filespec`可以包含通配符`*`和`?`,但不应包含路径。 4. **BeginBrowseFilenames(const char* filespec)**: 类似于`BeginBrowse`,但返回一个包含所有匹配文件名的`vector<string>`。 5. **BrowseDir(const char* dir, const char* filespec)**: 这是实际遍历目录的函数,递归地处理子目录和文件。如果遍历过程中遇到问题或用户中止,返回`false`。 6. **GetDirFilenames(const char* dir, const char* filespec)**: 获取指定目录下符合`filespec`的文件名列表。 7. **ProcessFile(const char* file)**: 每遍历到一个文件时调用此虚函数。默认行为可能是打印文件名,但可以通过继承`CBrowseDir`并重写此函数来实现自定义处理。 在使用`CBrowseDir`时,应注意以下几点: - **相对路径问题**: 如果使用相对路径,遍历后生成的文件可能会出现在错误的位置。因此,获取所有文件名后,需要调用`SetInitDir`将初始目录更改为当前目录。 - **通配符使用**: `*`匹配零个或多个任意字符,`?`匹配单个任意字符。 - **文件遍历的中断**: 用户可以通过返回`false`从`ProcessFile`中止遍历。 - **安全性和效率**: 考虑到C++中遍历文件夹的不便利性,作者建议使用脚本语言(如Python、Bash等)来处理文件遍历任务,这可能更高效且更易于实现。 `CBrowseDir`类提供了一个实用的工具,用于在C++程序中遍历目录和处理文件,但同时也提示了使用脚本语言可能带来的优势。在实际开发中,根据项目需求和团队习惯选择合适的方法。