调用linux的系统函数,实现tree的功能,递归打印文件夹
使用到得函数:
DIR *opendir(const char *name); // 打开文件夹 struct dirent *readdir(DIR *dirp); // 遍历文件夹 int closedir(DIR *dirp); // 关闭文件夹
代码如下:
/** * 递归打印文件夹 * @param filePath 要打印的文件路径 * @param space 当前文件夹的层次 */ void printFileTree(string filePath, int space) { string currPath = filePath; // 保存当前路径 DIR *dir = opendir(filePath.c_str()); // 打开当前文件夹 if (dir == nullptr) return; // 如果文件夹为空,则退出 dirent *dirTree; // readdir函数读取完当前文件后,会自动跳到下一个文件,如果读取完毕,会返回nullptr while ((dirTree = readdir(dir))) { // 不打印. ..以及隐藏的文件 if (dirTree->d_name[0] == '.' || strcmp(dirTree->d_name, "..") == 0) continue; for (int i = 0; i < space; ++i) { // 打印提示符 if (i == space - 1) cout << "|---"; else cout << "| "; } cout << dirTree->d_name << endl; // 打印当前文件名 if (dirTree->d_type == DT_DIR) { printFileTree(currPath + '/' + dirTree->d_name, space + 1); // 如果是文件夹,则继续递归 } } closedir(dir); // 关闭当前文件夹 }
结果展示