这里主要利用scandir函数,scandir中文件名排序有两种,alpthasort()和versionsort()。
其中alpthasort()是通过字母顺序进行排序,先判断首字母;
versionsort()则是通过字符串字段(*a)->d_name?和(*b)->d_name?上应用?strverscmp(3),
strverscmp?()的任务是比较两个字符串并找到“正确”的顺序,而strcmp(3)只查找字典顺序。此函数不使用语言环境类别LC_COLLATE,因此主要用于期望字符串为 ASCII 的情况。
这个函数的作用如下。如果两个字符串相等,则返回0。否则,找到两个字节之间的位置,在它之前两个字符串相等,而直接在它之后有一个差异。查找包含(或开始或结束)该位置的最大连续数字字符串。如果其中一个或两个为空,则返回strcmp(3)将返回的内容(字节值的数字排序)。否则,以数字方式比较两个数字字符串,其中具有一个或多个前导零的数字字符串被解释为好像它们前面有一个小数点(因此特别是具有更多前导零的数字字符串位于具有较少前导零的数字字符串之前)。因此,排序是000?,?00?,?01,?010?,?09?,?0?,?1?,?9?,?10。
#include <iterator>
#include <iostream>
#include <vector>
#include <stdio.h>
#include <dirent.h> //需要自己对该库进行配置
using namespace std;
int fileNameFilter(const struct dirent *cur) {
std::string str(cur->d_name);
if (str.find(".jpg") != std::string::npos) { //筛选.jpg为后缀的图片。
return 1;
}
return 0;
}
std::vector<std::string> getDirBinsSortedPath(std::string Path) { //输入参数为路径
struct dirent **namelist;
std::vector<std::string> ret;
int n = scandir(Path.c_str(), &namelist, fileNameFilter, versionsort); //通过ASCII排序
if (n < 0) {
return ret;
}
for (int i = 0; i < n; ++i) {
std::string filePath(namelist[i]->d_name);
ret.push_back(filePath);
free(namelist[i]);
};
free(namelist);
return ret;
}
如有讲错,请批评指正。
|