C++利用opencv 按顺序遍历文件夹图片

这里主要利用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 , 01010 , 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;
}

如有讲错,请批评指正。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值