linux

Linux readdir实现文件排序

小樊
45
2025-12-15 08:24:39
栏目: 智能运维

在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系统。

0
看了该问题的人还看了