C++ 从文件夹中读取文件

OpenCV从文件夹中读取内含文件方法

参考:http://www.2cto.com/kf/201407/316515.html

http://www.it610.com/article/5126146.htm

http://blog.csdn.net/adong76/article/details/39432467

windows平台代码:

[cpp] view plaincopy
在CODE上查看代码片派生到我的代码片
  1. #include <io.h>  
  2. #include <fstream>  
  3. #include <string>  
  4. #include <vector>  
  5. #include <iostream>  
  6.  using namespace std;  
  7.   
  8.   
  9. //获取所有的文件名  
  10. void GetAllFiles( string path, vector<string>& files)    
  11. {    
  12.   
  13.     long   hFile   =   0;    
  14.     //文件信息    
  15.     struct _finddata_t fileinfo;    
  16.     string p;    
  17.     if((hFile = _findfirst(p.assign(path).append("\\*").c_str(),&fileinfo)) !=  -1)    
  18.     {    
  19.         do    
  20.         {     
  21.             if((fileinfo.attrib &  _A_SUBDIR))    
  22.             {    
  23.                 if(strcmp(fileinfo.name,".") != 0  &&  strcmp(fileinfo.name,"..") != 0)    
  24.                 {  
  25.                     files.push_back(p.assign(path).append("\\").append(fileinfo.name) );  
  26.                     GetAllFiles( p.assign(path).append("\\").append(fileinfo.name), files );   
  27.                 }  
  28.             }    
  29.             else    
  30.             {    
  31.                 files.push_back(p.assign(path).append("\\").append(fileinfo.name) );    
  32.             }   
  33.   
  34.         }while(_findnext(hFile, &fileinfo)  == 0);    
  35.   
  36.         _findclose(hFile);   
  37.     }   
  38.   
  39. }    
  40.   
  41. //获取特定格式的文件名  
  42. void GetAllFormatFiles( string path, vector<string>& files,string format)    
  43. {    
  44.     //文件句柄    
  45.     long   hFile   =   0;    
  46.     //文件信息    
  47.     struct _finddata_t fileinfo;    
  48.     string p;    
  49.     if((hFile = _findfirst(p.assign(path).append("\\*" + format).c_str(),&fileinfo)) !=  -1)    
  50.     {    
  51.         do    
  52.         {      
  53.             if((fileinfo.attrib &  _A_SUBDIR))    
  54.             {    
  55.                 if(strcmp(fileinfo.name,".") != 0  &&  strcmp(fileinfo.name,"..") != 0)    
  56.                 {  
  57.                     //files.push_back(p.assign(path).append("\\").append(fileinfo.name) );  
  58.                     GetAllFormatFiles( p.assign(path).append("\\").append(fileinfo.name), files,format);   
  59.                 }  
  60.             }    
  61.             else    
  62.             {    
  63.                 files.push_back(p.assign(path).append("\\").append(fileinfo.name) );    
  64.             }    
  65.         }while(_findnext(hFile, &fileinfo)  == 0);    
  66.   
  67.         _findclose(hFile);   
  68.     }   
  69. }   
  70.   
  71. // 该函数有两个参数,第一个为路径字符串(string类型,最好为绝对路径);  
  72. // 第二个参数为文件夹与文件名称存储变量(vector类型,引用传递)。  
  73. // 在主函数中调用格式(并将结果保存在文件"AllFiles.txt"中,第一行为总数):  
  74.   
  75. int main()  
  76. {  
  77.     string filePath = "testimages\\water";    
  78.     vector<string> files;    
  79.     char * distAll = "AllFiles.txt";  
  80.   
  81.     //读取所有的文件,包括子文件的文件  
  82.     //GetAllFiles(filePath, files);  
  83.   
  84.     //读取所有格式为jpg的文件  
  85.     string format = ".jpg";  
  86.     GetAllFormatFiles(filePath, files,format);  
  87.     ofstream ofn(distAll);  
  88.     int size = files.size();   
  89.     ofn<<size<<endl;  
  90.     for (int i = 0;i<size;i++)    
  91.     {    
  92.         ofn<<files[i]<<endl;   
  93.         cout<< files[i] << endl;  
  94.     }  
  95.     ofn.close();  
  96.     return 0;  
  97. }  

Linux平台代码:

[cpp] view plaincopy
在CODE上查看代码片派生到我的代码片
  1. //LINUX/UNIX c获取某个目录下的所有文件的文件名  
  2.    
  3. #include <stdio.h>  
  4. #include <dirent.h>  
  5. int main(int argc, char * argv[])  
  6. {  
  7.     struct dirent *ptr;      
  8.     DIR *dir;  
  9.     dir=opendir("./file");  
  10.     printf("文件列表:\n");  
  11.     while((ptr=readdir(dir))!=NULL)  
  12.     {  
  13.    
  14.         //跳过'.'和'..'两个目录  
  15.         if(ptr->d_name[0] == '.')  
  16.             continue;  
  17.         printf("%s\n",ptr->d_name);  
  18.     }  
  19.     closedir(dir);  
  20.     return 0;  
  21. }  

C++ 版本

[cpp] view plaincopy
在CODE上查看代码片派生到我的代码片
  1. #include <iostream>  
  2. #include <vector>  
  3. #include <string>  
  4. #include <dirent.h>  
  5. using namespace std;  
  6.   
  7. int main(int argc, char * argv[])  
  8. {  
  9.     struct dirent *ptr;      
  10.     DIR *dir;  
  11.     string PATH = "./file";  
  12.     dir=opendir(PATH.c_str());   
  13.     vector<string> files;  
  14.     cout << "文件列表: "<< endl;  
  15.     while((ptr=readdir(dir))!=NULL)  
  16.     {  
  17.    
  18.         //跳过'.'和'..'两个目录  
  19.         if(ptr->d_name[0] == '.')  
  20.             continue;  
  21.         //cout << ptr->d_name << endl;  
  22.         files.push_back(ptr->d_name);  
  23.     }  
  24.       
  25.     for (int i = 0; i < files.size(); ++i)  
  26.     {  
  27.         cout << files[i] << endl;  
  28.     }  
  29.   
  30.     closedir(dir);  
  31.     return 0;  
  32. }  

_finddata_t 的使用  


那么到底如何查找文件呢?我们需要一个结构体和几个大家可能不太熟悉的函数。这些函数和结构体在<io.h>的头文件中,结构体为struct _finddata_t ,函数为_findfirst、_findnext和_fineclose。具体如何使用,我会慢慢讲来~
        首先讲这个结构体吧~ struct _finddata_t ,这个结构体是用来存储文件各种信息的。说实话,这个结构体的具体定义代码,我没有找到,不过还好,文档里面在_find里有比较详细的成员变量介绍。我基本上就把文档翻译过来讲吧:


        unsigned atrrib:文件属性的存储位置。它存储一个unsigned单元,用于表示文件的属性。文件属性是用位表示的,主要有以下一些:_A_ARCH(存档)、_A_HIDDEN(隐藏)、_A_NORMAL(正常)、_A_RDONLY(只读)、_A_SUBDIR(文件夹)、_A_SYSTEM(系统)。这些都是在<io.h>中定义的宏,可以直接使用,而本身的意义其实是一个无符号整型(只不过这个整型应该是2的几次幂,从而保证只有一位为1,而其他位为0)。既然是位表示,那么当一个文件有多个属性时,它往往是通过位或的方式,来得到几个属性的综合。例如只读+隐藏+系统属性,应该为:_A_HIDDEN | _A_RDONLY | _A_SYSTEM 。

       time_t time_create:这里的time_t是一个变量类型(长整型?相当于long int?),用来存储时间的,我们暂时不用理它,只要知道,这个time_create变量是用来存储文件创建时间的就可以了。


        time_t time_access:文件最后一次被访问的时间。


        time_t time_write:文件最后一次被修改的时间。


        _fsize_t size:文件的大小。这里的_fsize_t应该可以相当于unsigned整型,表示文件的字节数。


        char name[_MAX_FNAME]:文件的文件名。这里的_MAX_FNAME是一个常量宏,它在<stdlib.h>头文件中被定义,表示的是文件名的最大长度。


        以此,我们可以推测出,struct _finddata_t ,大概的定义如下:


        struct _finddata_t
        {
             unsigned attrib;
             time_t time_create;
             time_t time_access;
             time_t time_write;
             _fsize_t size;
             char name[_MAX_FNAME];
        };


        前面也说了,这个结构体是用来存储文件信息的,那么如何把一个硬盘文件的文件信息“存到”这个结构体所表示的内存空间里去呢?这就要靠_findfirst、_findnext和_fineclose三个函数的搭配使用了。


        首先还是对这三个函数一一介绍一番吧……


        long _findfirst( char *filespec, struct _finddata_t *fileinfo );


        返回值:如果查找成功的话,将返回一个long型的唯一的查找用的句柄(就是一个唯一编号)。这个句柄将在_findnext函数中被使用。若失败,则返回-1。


        参数:


        filespec:标明文件的字符串,可支持通配符。比如:*.c,则表示当前文件夹下的所有后缀为C的文件。


        fileinfo :这里就是用来存放文件信息的结构体的指针。这个结构体必须在调用此函数前声明,不过不用初始化,只要分配了内存空间就可以了。函数成功后,函数会把找到的文件的信息放入这个结构体中。


        int _findnext( long handle, struct _finddata_t *fileinfo );


        返回值:若成功返回0,否则返回-1。


        参数:


        handle:即由_findfirst函数返回回来的句柄。


        fileinfo:文件信息结构体的指针。找到文件后,函数将该文件信息放入此结构体中。


       int _findclose( long handle );


        返回值:成功返回0,失败返回-1。

        参数:


        handle:即由_findfirst函数返回回来的句柄。


        fileinfo:文件信息结构体的指针。找到文件后,函数将该文件信息放入此结构体中。


       int _findclose( long handle );


        返回值:成功返回0,失败返回-1。


        参数:


        handle :_findfirst函数返回回来的句柄。


        大家看到这里,估计都能猜到个大概了吧?先用_findfirst查找第一个文件,若成功则用返回的句柄调用_findnext函数查找其他的文件,当查找完毕后用,用_findclose函数结束查找。恩,对,这就是正确思路。下面我们就按照这样的思路来编写一个查找C:\WINDOWS文件夹下的所有exe可执行文件的程序。


        #include <stdio.h>
        #include <io.h>


        const char *to_search="C:\\WINDOWS\\*.exe";        //欲查找的文件,支持通配符


        int main()
        {
             long handle;                                                //用于查找的句柄
             struct _finddata_t fileinfo;                          //文件信息的结构体
             handle=_findfirst(to_search,&fileinfo);         //第一次查找
             if(-1==handle)return -1;
             printf("%s\n",fileinfo.name);                         //打印出找到的文件的文件名
             while(!_findnext(handle,&fileinfo))               //循环查找其他符合的文件,知道找不到其他的为止
             {
                  printf("%s\n",fileinfo.name);
            }
             _findclose(handle);                                      //别忘了关闭句柄
             system("pause");
             return 0;
        }


        当然,这个文件的查找是在指定的路径中进行,如何遍历硬盘,在整个硬盘中查找文件呢?大家可以在网络上搜索文件递归遍历等方法,这里不再做进一步介绍。

        程序的末尾用了一个system函数。这个与程序本身并没有影响,和以前介绍给大家的使用getchar()函数的作用相同,只是为了暂停一下,让我们能看到命令提示符上输出的结果而已。不过system函数本身是一个非常强大的函数。大家可以查查MSDN看看~ 简单来说,它是一个C语言与操作系统的相互平台,可以在程序里通过这个函数,向操作系统传递command


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/313253.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

你必须知道的容器监控 (1) Docker自带子命令与Weave Scope

本篇已加入《》&#xff0c;可以点击查看更多容器化技术相关系列文章。本篇会介绍几个目前比较常用且流行的容器监控工具&#xff0c;首先我们来看看Docker自带的几个监控子命令&#xff1a;ps、top以及stats&#xff0c;然后是一个功能更强的开源监控工具Weave Scope。# 实验环…

char *与char []

由于指针的灵活性&#xff0c;导致指针能代替数组使用&#xff0c;或者混合使用&#xff0c;这些导致了许多指针和数组的迷惑&#xff0c;因此&#xff0c;刻意再次深入探究了指针和数组这玩意儿&#xff0c;其他类型的数组比较简单&#xff0c;容易混淆的是字符数组和字符指针…

.NET Core ORM 类库Petapoco中对分页Page添加Order By对查询的影响

介绍最近一直在使用PetapocoEntity Framework Core结合开发一套系统。使用EFCore进行Code First编码&#xff0c;使用使用Petapoco进行数据库的常规操作。并且结合PetaPoco.SqlKata的使用&#xff0c;减少了编写SQL语句的工作量&#xff0c;对提升开发效率有很大的帮助。Petapo…

.Net Core 3.0 IdentityServer4 快速入门

一、简介IdentityServer4是用于ASP.NET Core的OpenID Connect和OAuth 2.0框架。将IdentityServer4部署到您的应用中具备如下特点&#xff1a;1&#xff09;、认证服务2&#xff09;、单点登陆3&#xff09;、API访问控制4&#xff09;、联合网关5&#xff09;、专注于定制6&…

.NET Core3.0创建Worker Services

.NET CORE 3.0新增了Worker Services的新项目模板&#xff0c;可以编写长时间运行的后台服务&#xff0c;并且能轻松的部署成windows服务或linux守护程序。如果安装的vs2019是中文版本&#xff0c;Worker Services变成了辅助角色服务。Worker Services 咱也不知道怎么翻译成了这…

OpenCV Mat数据类型像素操作

转自&#xff1a;http://blog.csdn.net/skeeee/article/details/13297457 OpenCV图像像素操作及效率分析 在计算机视觉应用中&#xff0c;对于图像内容的读取分析是第一步&#xff0c;所以学习高效的处理图像是很有用的。一个图像有可能包含数以万计的像素&#xff0c;从根本上…

Bumblebee微服务网关之Url重写

为了提高Url访问的统一和友好性&#xff0c;一般访问的Url和服务定义的Url有所不同;为了解决这一问题Bumblebee提供Url重写功能;通过Url重写功能可以在转发前进行一个重写后再转发到后台服务。引用插件Bumblebee中使用Url重写需要引用两个插件&#xff0c;分别是Bumblebee.Conf…

依赖注入:一个Mini版的依赖注入框架

前面的章节中&#xff0c;我们从纯理论的角度对依赖注入进行了深入论述&#xff0c;我们接下来会对.NET Core依赖注入框架进行单独介绍。为了让读者朋友能够更好地理解.NET Core依赖注入框架的设计与实现&#xff0c;我们按照类似的原理创建了一个简易版本的依赖注入框架&#…

.NET Core 3.0 新 JSON API - JsonSerializer

JsonSerializer 前面几节的内容可能稍微有点底层&#xff0c;我们大部分时候可能只需要对C#的类进行串行化或者将JSON数据反串行化成C#类&#xff0c;在.NET Core 3.0里面&#xff0c;我们可以使用JsonSerializer这个类来做这些事情。 例子 还是使用之前用到的json数据&#xf…

Caffe查看每一层学习出来的pattern

Filter visualization http://www.cnblogs.com/dupuleng/articles/4244877.html 这一节参考http://nbviewer.ipython.org/github/BVLC/caffe/blob/master/examples/filter_visualization.ipynb&#xff0c;主要介绍如何显示每一层的参数及输出&#xff0c;这一部分非常重要&am…

.NET Core 3.0 新 JSON API - Utf8JsonWriter

Utf8JsonWriter类 下面研究一下如何写入json文件。这里需要使用Utf8JsonWriter类。 直接看代码&#xff1a; 这个类需要传递的参数类型是Stream或者Buffer&#xff0c;也就是向Stream或Buffer里面写入数据。 那么就提供一个buffer&#xff1a; 下面单独写一个方法&#xff0c;来…

python查看CNN训练模型参数

参照&#xff1a;http://blog.csdn.net/u011762313/article/details/49851795 #!/usr/bin/env python# 引入“咖啡” import caffeimport numpy as np# 使输出的参数完全显示 # 若没有这一句&#xff0c;因为参数太多&#xff0c;中间会以省略号“……”的形式代替 np.set_prin…

Bumblebee微服务网关之consul服务发现

网关需要维护相关负载的服务器&#xff0c;手动添加相对来说是一件比较麻烦的工作&#xff1b;为了解决这一问题组件扩展了一个基于consul服务发现插件&#xff0c;通过配置这个插件和启用后网关会自动从consul服务中获取服务并添加到网关对应的路由负载规则中。引用插件Bumble…

Github带来的不止是开源,还有折叠的认知

几乎每个程序员都知道github&#xff0c;但是知道目前上面有多少repositories的估计没几个。Z哥今天去看了下&#xff0c;最新的数量显示是1.39亿个。▲截图来自于github.com而这个数字在2008年那会只是3.3万个。这个增长速度可谓真的是“爆炸式增长”。与此同时&#xff0c;大…

最优间隔分类器-SVM

http://blog.csdn.net/Andrewseu/article/details/46991541 本讲大纲&#xff1a; 1.最优间隔分类器(optimal margin classifier) 2.原始/对偶优化问题&#xff08;KKT&#xff09;&#xff08;primal/dual optimization problem&#xff09; 3.SVM对偶(SVM dual) 4.核方法(…

自动给 Asp.Net Core Api 增加 ApiVersionNeutral

自动给 Asp.Net Core Api 增加 ApiVersionNeutralIntro新增加一个 Controller 的时候&#xff0c;经常忘记在 Controller 上增加 ApiVersion &#xff0c;结果就导致前端使用指定的 ApiVersion 访问的时候就会失败&#xff0c;不支持的 Api 版本。错误信息如下&#xff1a;{ &q…

K-means与高斯混合模型

K-means http://blog.pluskid.org/?p17 Clustering 中文翻译作“聚类”&#xff0c;简单地说就是把相似的东西分到一组&#xff0c;同 Classification (分类)不同&#xff0c;对于一个 classifier &#xff0c;通常需要你告诉它“这个东西被分为某某类”这样一些例子&#xf…

轻量级ORM《sqlcommon》第一个版本发布了

一、sqlcommon的特色1. 轻量级&#xff0c;整个包只有123kb。2. 性能好&#xff0c;自测。。。3. API和功能简单、代码简短、可维护性好基本都能看懂。这个点我认为很重要&#xff0c;你不用为了实现一个需求而四处查资料&#xff0c;这意味着这个包你可以自行维护修改&#xf…

从基于直方图的Graph-Cut到Grab-Cut

http://blog.csdn.net/zouxy09/article/details/8534954 区别&#xff1a; &#xff08;1&#xff09;Graph Cut的目标和背景的模型是灰度直方图&#xff0c;Grab Cut取代为RGB三通道的混合高斯模型GMM&#xff1b; &#xff08;2&#xff09;Graph Cut的能量最小化&#xf…

1024程序员节活动继续:购书优惠劵,折后再折,赶紧来抢啊

1024程序员节当当网计算机图书每满100减50&#xff01;满200减100&#xff01;满300-150&#xff01;机械工业出版社华章公司联合当当网特意为【DotNET技术圈】用户申请了一批可与满减叠加使用的“满200减30”的图书优惠码&#xff0c;优惠码使用后相当于&#xff1a;400减230 …