如何遍历一个文件夹下的所有子文件夹,文件??绝对给满分。 要把文件名记录下来,写到一个文本文件中。多谢!!!!! 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 see this,maybe help you.http://www.codeproject.com/treectrl/pathpicker.asp 遍历方法: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; }}2,栈的方法类似,请参考数据结构中关于树的非递归遍历 void ::GetFolderInformation(CString strFolderName){ CFileFind f; BOOL bFind=f.FindFile(strFolderName+"\\*.*"); while(bFind) { bFind = f.FindNextFile(); if(f.IsDots()) continue; if(f.IsDirectory()) { GetFolderInformation(strFolderName+f.GetFileName()); //strFolderName+f.GetFileName()就是你要的文件夾名 } TRACE(_T("%s\r\n"),f.GetFileName());// f.GetFileName()是文件名 }} 先定义一个全局文件类型的指针变量fp代表要写入的文件实体(预先打开,直接准备写)void func(LPSTR lpPath){ WIN32_FIND_DATA fdata; ......... hFile=FindFistFile(lpPath,&fdata) if(INVALID_HANDLE_VALUE!=hFile) { while(FindNextFile(&fdata) { if(fdata.dwFileAttributes&FILE_ATTRIBUTE_DIRECTORY) { ............. Func(fdata.cFileName); .............. } ........ fscanf(fp,"%s\n",fdata.cFileName); } }} findxfile系列函数,看msdn吧。不需要说得更详细了吧 应用程序的开发过程中,经常会遇到如何查找某一文件以确定此文件路径的问题。利用CFileFind类可以比较方便地在当前目录下进行文件查找,但却不能对其子目录中的文件进行搜寻。而实际应用中往往需要对某一整个目录树,甚至是整个C盘或D盘驱动器进行文件搜寻。通过实践,我们在Visual C++ 6.0中编程实现了如何遍历任意目录树,以查找某一特定的文件。 在下面的具体陈述中可以看到,在确定要查找的文件名和要进行搜索的目录的名称后,将调用函数Search_Directory进行文件的查找。首先依次查找当前目录下的每一个实体(文件或是子目录),如果是某一子目录,则进入该子目录并递归调用函数Search_Dirctory进行查找,查找完毕之后, 再返回上一级目录;如果不是子目录而是某一文件,则判断其是否就是我们要查找的文件,如果是则输出其完整的文件路径。这样,通过Search_Directory函数的反复递归调用,就可以实现对整个目录,包括子目录的遍历搜索。下面将举例详细讲述如何在VC++中编程实现在整个目录树中的文件查找。 1.在Visual C++ 6.0(VC++ 5.0与之类似)中用默认方式创建了一基于对话框的应用程序Search。在主窗口对话框上放置一命令按钮,其Caption为“Search File”,ID为ID—BUTTON—SEARCH。单击此按钮将完成文件的查找工作。 2.利用ClassWizard为“Search File”按钮的BN_CLICKED 事件添加处理函数OnButtonSearch,代码如下: #include 〈direct.h〉 #include 〈io.h〉 ...... void CSearchDlg::OnButtonSearch() { // TODO: Add your control notification handler code here char szFilename[80]; // 字符串 szFilename 表示要查找的文件名 strcpy(szFilename,″Mytext.txt″); _chdir(″d:\\″); // 进入要查找的路径(也可为某一具体的目录) // 查找文件, 如果查到则显示文件的路径全名 Search_Directory(szFilename); // 为CSearchDlg类的一成员函数 MessageBox(″查找文件完毕!″); // 显示查找完毕的信息 } 3.在CSearchDlg类中增加成员函数Search_Directory,它将完成具体的文件查找工作,代码如下: void CSearchDlg::Search_Directory(char* szFilename) { long handle; struct _finddata_t filestruct; //表示文件(或目录)的信息 char path_search[_MAX_PATH]; //表示查找到的路径结果 // 开始查找工作, 找到当前目录下的第一个实体(文件或子目录), // ″*″表示查找任何的文件或子目录, filestruct为查找结果 handle = _findfirst(″*″, &filestruct); // 如果handle为-1, 表示当前目录为空, 则结束查找而返回 if((handle == -1)) return; // 检查找到的第一个实体是否是一个目录(filestruct.name为其名称) if( ::GetFileAttributes(filestruct.name) & FILE—ATTRIBUTE—DIRECTORY ) { // 如果是目录, 则进入该目录并递归调用函数Search_Dirctory进行查找, // 注意: 如果目录名的首字符为′.′(即为″.″或″..″), 则不用进行查找 if( filestruct.name[0] != ′.′ ) { —chdir(filestruct.name); Search_Directory(szFilename); // 查找完毕之后, 返回上一级目录 —chdir(″..″); } } else // 如果第一个实体不是目录, 则检查是否是要查找的文件 { // stricmp对两字符串进行小写形式的对比, 返回为0表示完全一致 if( !stricmp(filestruct.name, szFilename) ) { // 先获得当前工作目录的全路径 —getcwd(path_search,—MAX—PATH); // 再获得文件的完整的路径名(包含文件的名称) strcat(path_search,″\\″); strcat(path—search,filestruct.name); MessageBox(path_search); //输出显示 } } // 继续对当前目录中的下一个子目录或文件进行与上面同样的查找 while(!(—findnext(handle,&filestruct))) { if( ::GetFileAttributes(filestruct.name) & FILE—ATTRIBUTE—DIRECTORY ) { if(*filestruct.name != ′.′) { —chdir(filestruct.name); Search_Directory(szFilename); —chdir(″..″); } } else { if(!stricmp(filestruct.name,szFilename)) { —getcwd(path—search,—MAX—PATH); strcat(path_search,″\\″); strcat(path_search,filestruct.name); MessageBox(path_search); } } } —findclose(handle); // 最后结束整个查找工作 } 这样我们就可以对整个目录进行遍历搜索,查找某一特定的文件,并输出显示其完整的文件路径。以上的程序在Visual C++ 6.0中已调试通过。转载于:计算机世界日报怎么样够全了吧!好不容易找到的。^-^ 我知道两种思想一是前面大家提到的递归。递归,栈都是基于这种思想,就是列出当前目录下的所有文件,如果文件属性是个子目录,进入子目录,刚才的操作,返回。二是用队列。和思想一不同的是碰到子目录并不马上进入,而是先将其放入队列,遍历完当前目录后从队列读入下一个目录。第一种方法比较常用,如大家给出的程序;第二种办法在一些特定场合有用,比如遍历ftp。 DWORD __fastcall ScanFile::FindFileInDir(TCHAR *Dir, TCHAR *FileExt, BOOL Auth)//Dir是目录名,FileExt是要查找的扩展名,Auth对你没有意义。{ WIN32_FIND_DATA FileData; HANDLE hSearch; BOOL fFinished = FALSE; DWORD iCount=0; TCHAR FindFiles[MAX_PATH+1]; FIND_FILE ff; wsprintf(FindFiles,TEXT("%s\\*.*"),Dir);// ::MessageBox(hWnd,FindFiles,NULL,MB_OK); hSearch = FindFirstFile(FindFiles, &FileData); if(hSearch == INVALID_HANDLE_VALUE) { return 0; } while (!fFinished&&!g_UserBreak) { if((FileData.dwFileAttributes&FILE_ATTRIBUTE_DIRECTORY)==FILE_ATTRIBUTE_DIRECTORY) { if(*(FileData.cFileName)!='.') { wsprintf(FindFiles,TEXT("%s\\%s"),Dir,FileData.cFileName); ::SendMessage(hWnd,WM_FINDING,0,(LPARAM)FindFiles); FindFileInDir(FindFiles,FileExt,Auth); } } else if(ExtractFileExt(AnsiString(FileData.cFileName)).UpperCase()==AnsiString(FileExt).UpperCase()) { iCount++; ff.fd=FileData; lstrcpyn(ff.Dir,Dir,MAX_PATH); ff.AuthReq=Auth; lstrcpyn(ff.User,TEXT("guest"),255); lstrcpyn(ff.Pass,TEXT("guest"),255); ff.pNode=pTreeNode; ::SendMessage(hWnd,WM_FINDFILE,iCount,(LPARAM)&ff); } if (!FindNextFile(hSearch, &FileData)) { if (GetLastError() == ERROR_NO_MORE_FILES) { fFinished = TRUE; } else { return 0; } } } FindClose(hSearch); return iCount;}//--------------------------------------------------------------------------- 有一个类似的, 你自己改改!//函数描述:函数名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;} NetBIOS编程 求itk optimizer Powell代码 directx如何读写显存? 坐标位置问题和坐标转换的问题 有没有谁用过oarcle的OCI接口啊? COM无法注册,请帮助解决: 菜人想读取bmp图象,然后实现在上面进行画线等,最后存储的问题(分不够,再加) 问大家一个特别傻的问题,但是请务必帮我解答,谢谢了 谁能提供一个DBGrid控见使用的例子,my e_mail:lixia_zhang@hotmail谢谢!倾分奉送 求助CLR winform 如何获取dll中获得的数据 如何用VC在NT下做一个用户管理程序 请问 HWND_DESKTOP 是什么意思?
http://www.codeproject.com/treectrl/pathpicker.asp
关键函数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;
}
}
2,栈的方法类似,请参考数据结构中关于树的非递归遍历
{
CFileFind f;
BOOL bFind=f.FindFile(strFolderName+"\\*.*");
while(bFind)
{
bFind = f.FindNextFile();
if(f.IsDots()) continue;
if(f.IsDirectory())
{
GetFolderInformation(strFolderName+f.GetFileName());
//strFolderName+f.GetFileName()就是你要的文件夾名
}
TRACE(_T("%s\r\n"),f.GetFileName());
// f.GetFileName()是文件名
}
}
(预先打开,直接准备写)void func(LPSTR lpPath)
{
WIN32_FIND_DATA fdata;
.........
hFile=FindFistFile(lpPath,&fdata)
if(INVALID_HANDLE_VALUE!=hFile)
{
while(FindNextFile(&fdata)
{
if(fdata.dwFileAttributes&FILE_ATTRIBUTE_DIRECTORY)
{
.............
Func(fdata.cFileName);
..............
}
........
fscanf(fp,"%s\n",fdata.cFileName);
}
}
}
怎么样够全了吧!好不容易找到的。^-^
一是前面大家提到的递归。
递归,栈都是基于这种思想,就是列出当前目录下的所有文件,如果文件属性是个子目录,进入子目录,刚才的操作,返回。
二是用队列。和思想一不同的是碰到子目录并不马上进入,而是先将其放入队列,遍历完当前目录后从队列读入下一个目录。
第一种方法比较常用,如大家给出的程序;第二种办法在一些特定场合有用,比如遍历ftp。
//Dir是目录名,FileExt是要查找的扩展名,Auth对你没有意义。
{
WIN32_FIND_DATA FileData;
HANDLE hSearch;
BOOL fFinished = FALSE;
DWORD iCount=0;
TCHAR FindFiles[MAX_PATH+1];
FIND_FILE ff; wsprintf(FindFiles,TEXT("%s\\*.*"),Dir);
// ::MessageBox(hWnd,FindFiles,NULL,MB_OK);
hSearch = FindFirstFile(FindFiles, &FileData);
if(hSearch == INVALID_HANDLE_VALUE)
{
return 0;
}
while (!fFinished&&!g_UserBreak)
{
if((FileData.dwFileAttributes&FILE_ATTRIBUTE_DIRECTORY)==FILE_ATTRIBUTE_DIRECTORY)
{
if(*(FileData.cFileName)!='.')
{
wsprintf(FindFiles,TEXT("%s\\%s"),Dir,FileData.cFileName);
::SendMessage(hWnd,WM_FINDING,0,(LPARAM)FindFiles);
FindFileInDir(FindFiles,FileExt,Auth);
}
}
else if(ExtractFileExt(AnsiString(FileData.cFileName)).UpperCase()==AnsiString(FileExt).UpperCase())
{
iCount++;
ff.fd=FileData;
lstrcpyn(ff.Dir,Dir,MAX_PATH);
ff.AuthReq=Auth;
lstrcpyn(ff.User,TEXT("guest"),255);
lstrcpyn(ff.Pass,TEXT("guest"),255);
ff.pNode=pTreeNode;
::SendMessage(hWnd,WM_FINDFILE,iCount,(LPARAM)&ff);
}
if (!FindNextFile(hSearch, &FileData))
{
if (GetLastError() == ERROR_NO_MORE_FILES)
{
fFinished = TRUE;
}
else
{
return 0;
}
}
}
FindClose(hSearch);
return iCount;
}
//---------------------------------------------------------------------------
//功能:取指定目录下的所有文件,
//参数描述: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;
}