遍历方法:1递归,2,栈
关键函数FindFirstFile,FirstNextFile(见msdn)
1,递归,(大致如下)
void func(LPSTR lpPath)
{
WIN32_FIND_DATA fdata;
.........
hFile=FindFistFile(lpPath,&fdata)
while(INVALID_HANDLE_VALUE!=hFile)
{
if(fdata.dwFileAttributes&FILE_ATTRIBUTE_DIRECTORY)
{
.............
Func(fdata.cFileName);
..............
}
........
if(FindNextFile(hFile,...)==FALSE)
break;
}
}
//函数描述:函数名Fget_filename
//功能:取指定目录下的所有文件,
//参数描述:fdirectoryPath为指定路径,
// filename_array存放取得的文件名信息的数组,
// length数组实际存放项的长度
//返回值描述:返回值1表示正常,-1表示出错
short Fget_filename( char* fdirectoryPath,char* filename_array[MAX1], int& length )
{
WIN32_FIND_DATA data; //is FindFirstFile Parameters
HANDLE hFind;
int nCount=0; //
char filename[256];
memset( filename, 0, 256 );
strcpy(filename, fdirectoryPath );
strcat(filename, "\\*.* ");
//查找当前目录下的所有文件
hFind = FindFirstFile(filename, &data);
while( hFind != INVALID_HANDLE_VALUE )
{
strcpy( filename_array[nCount], data.cFileName );
nCount++;
if( !FindNextFile(hFind, &data) )
{
CloseHandle( hFind );
hFind = INVALID_HANDLE_VALUE;
}
}
length=nCount;
return 1;
}
FindFirstFile
FindNextFile
如果想遍历所有文件和文件夹,以及所有子目录、子文件,则需要用SetCurrentDirectory设置当前的下一级目录,然后递归调用
-
C/C++ code
-
WIN32_FIND_DATA fd; HANDLE hFind = ::FindFirstFile( " C:\\*.* " , & fd); if (hFind != INVALID_HANDLE_VALUE) { do { printf(fd.cFileName); } while (::FindNextFile(hFind, & fd)); ::FindClose(hFind); }
这些代码在网上随便搜索一下就有
给你一小部分
CFileFind finder;
BOOL bWorking = finder.FindFile(MapPath);
while (bWorking)
{
bWorking = finder.FindNextFile();
if (!finder.IsDirectory() && !finder.IsDots())
{
ZeroMemory(MapPath + pathlen,256 - pathlen);
ZeroMemory(mapID,6);
strTitle = finder.GetFileName();
}
}