Linux readdir实现文件排序
导读:在Linux中,readdir函数用于读取目录中的文件和子目录 首先,确保你已经包含了必要的头文件: #include <dirent.h> #include <stdio.h> #include <stdli...
在Linux中,readdir函数用于读取目录中的文件和子目录
首先,确保你已经包含了必要的头文件:
#include <
dirent.h>
#include <
stdio.h>
#include <
stdlib.h>
#include <
string.h>
接下来,定义一个结构体来存储文件名和文件类型:
typedef struct {
char name[256];
int is_directory;
}
FileInfo;
然后,编写一个比较函数,用于qsort函数对文件进行排序:
int compare(const void *a, const void *b) {
FileInfo *file_a = (FileInfo *)a;
FileInfo *file_b = (FileInfo *)b;
return strcmp(file_a->
name, file_b->
name);
}
现在,编写一个函数来读取目录并填充FileInfo结构体数组:
int read_directory(const char *path, FileInfo *files, int max_files) {
DIR *dir = opendir(path);
if (!dir) {
perror("opendir");
return -1;
}
struct dirent *entry;
int count = 0;
while ((entry = readdir(dir)) != NULL &
&
count <
max_files) {
if (entry->
d_type == DT_REG || entry->
d_type == DT_DIR) {
strncpy(files[count].name, entry->
d_name, sizeof(files[count].name));
files[count].is_directory = (entry->
d_type == DT_DIR);
count++;
}
}
closedir(dir);
return count;
}
最后,在main函数中调用这些函数并使用qsort对文件进行排序:
int main(int argc, char *argv[]) {
if (argc != 2) {
fprintf(stderr, "Usage: %s <
directory_path>
\n", argv[0]);
return 1;
}
const char *path = argv[1];
FileInfo files[1024];
int file_count = read_directory(path, files, sizeof(files) / sizeof(files[0]));
if (file_count == -1) {
return 1;
}
qsort(files, file_count, sizeof(files[0]), compare);
for (int i = 0;
i <
file_count;
i++) {
printf("%s%s\n", files[i].is_directory ? " [DIR] " : " [FILE] ", files[i].name);
}
return 0;
}
编译并运行这个程序,它将读取指定目录中的文件和子目录,并按字母顺序输出它们。注意,这个程序仅适用于Linux系统。
声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!
若转载请注明出处: Linux readdir实现文件排序
本文地址: https://pptw.com/jishu/771973.html
