实现类似tree命令,c编程
时间: 2024-03-09 12:44:39 浏览: 14
要实现类似tree命令的功能,可以使用递归来遍历目录并输出文件结构。以下是一个简单的C程序实现:
```c
#include <stdio.h>
#include <stdlib.h>
#include <dirent.h>
#include <string.h>
void print_tree(char *path, int level) {
DIR *dir = opendir(path);
if (!dir) {
printf("Cannot open directory %s\n", path);
return;
}
struct dirent *entry;
while ((entry = readdir(dir)) != NULL) {
if (strcmp(entry->d_name, ".") == 0 || strcmp(entry->d_name, "..") == 0)
continue;
for (int i = 0; i < level; i++)
printf(" ");
printf("|- %s\n", entry->d_name);
char nextpath[1024];
snprintf(nextpath, sizeof(nextpath), "%s/%s", path, entry->d_name);
print_tree(nextpath, level + 1);
}
closedir(dir);
}
int main(int argc, char *argv[]) {
if (argc < 2) {
printf("Usage: %s <directory>\n", argv[0]);
return 1;
}
print_tree(argv[1], 0);
return 0;
}
```
这个程序接受一个命令行参数,即要遍历的目录,然后递归输出该目录下的所有文件和子目录。其中,`print_tree`函数用来实现递归遍历和输出,`main`函数用来解析命令行参数并调用`print_tree`函数。