今天早上接到一个任务,查找过程中觉得很有价值,转过来以后自己方便看。
这个代码主要实现的功能是:获取给定文件夹下所有的文件名列表,可递归查找子文件夹。
先是头文件,具体用到哪一个我还没有研究,以后再说吧,这个是在另一篇博客里找到的。
#include <iostream>
#include <io.h>
#include <direct.h>
#include <string>
#include <vector>
#include <iomanip>
#include <ctime>
using namespace std;
函数主体部分引用原来博主的例子好了:
char * filePath = "D:\\sample";
vector<string> files;
获取该路径下的所有文件
getFiles(filePath, files );
char str[30];
int size = files.size();
for (int i = 0;i < size;i++)
{
<span style="white-space:pre"> </span>cout<<files[i].c_str()<<endl;
}
void getFiles( string path, vector<string>& files )
{
//文件句柄
long hFile = 0;
//文件信息
struct _finddata_t fileinfo;
string p;
if((hFile = _findfirst(p.assign(path).append("\\*").c_str(),&fileinfo)) != -1)
{
do
{
//如果是目录,迭代之
//如果不是,加入列表
if((fileinfo.attrib & _A_SUBDIR))
{
if(strcmp(fileinfo.name,".") != 0 && strcmp(fileinfo.name,"..") != 0)
getFiles( p.assign(path).append("\\").append(fileinfo.name), files );
}
else
{
files.push_back(p.assign(path).append("\\").append(fileinfo.name) );
}
}while(_findnext(hFile, &fileinfo) == 0);
_findclose(hFile);
}
}
(转自http://blog.csdn.net/cxf7394373/article/details/7195661)