bool CTest_Thread1Dlg::Search()
{
CString str;
char *szFilename;
GetDlgItemText(IDC_FIND,str);
//szFilename=str.GetBuffer(szFilename);
szFilename = (LPSTR)(LPCTSTR)str;
AfxMessageBox(szFilename);
_chdir("d://"); // 进入要查找的路径(也可为某一具体的目录)
// 查找文件, 如果查到则显示文件的路径全名
// 为CSearchDlg类的一成员函数
if(!strcmp(Search_Directory(szFilename),""))
AfxMessageBox("查找文件完毕!");
else
AfxMessageBox("找不到要查找的文件");
return true;
}
char* CTest_Thread1Dlg::Search_Directory(char* szFilename)
{
long handle;
struct _finddata_t filestruct;
//表示文件(或目录)的信息
//path_search = "";
//表示查找到的路径结果
// 开始查找工作, 找到当前目录下的第一个实体(文件或子目录),
// "*"表示查找任何的文件或子目录, filestruct为查找结果
handle = _findfirst("*", &filestruct);
// 如果handle为-1, 表示当前目录为空, 则结束查找而返回
if((handle == -1))
return false;
// 检查找到的第一个实体是否是一个目录(filestruct.name为其名称)
if( ::GetFileAttributes(filestruct.name) & FILE_ATTRIBUTE_DIRECTORY )
{
// 如果是目录, 则进入该目录并递归调用函数Search_Dirctory进行查找,
// 注意: 如果目录名的首字符为'.'(即为"."或".."), 则不用进行查找
if( filestruct.name[0] != '.' )
{
_chdir(filestruct.name);
Search_Directory(szFilename);
// 查找完毕之后, 返回上一级目录
_chdir("..");
}
//else
// AfxMessageBox("查找当前目录无效");
}
else // 如果第一个实体不是目录, 则检查是否是要查找的文件
{
// stricmp对两字符串进行小写形式的对比, 返回为0表示完全一致
if( !stricmp(filestruct.name, szFilename) )
{
// 先获得当前工作目录的全路径
_getcwd(path_search,_MAX_PATH);
// 再获得文件的完整的路径名(包含文件的名称)
strcat(path_search,"\\");
strcat(path_search,filestruct.name);
//MessageBox(path_search); //输出显示
return path_search;
}
}
// 继续对当前目录中的下一个子目录或文件进行与上面同样的查找
bool flag = false;
while((!(_findnext(handle,&filestruct))&!flag))
{
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);
flag = true;
return path_search;
}
}
}
// 最后结束整个查找工作
_findclose(handle);
return path_search;
}
{
CString str;
char *szFilename;
GetDlgItemText(IDC_FIND,str);
//szFilename=str.GetBuffer(szFilename);
szFilename = (LPSTR)(LPCTSTR)str;
AfxMessageBox(szFilename);
_chdir("d://"); // 进入要查找的路径(也可为某一具体的目录)
// 查找文件, 如果查到则显示文件的路径全名
// 为CSearchDlg类的一成员函数
if(!strcmp(Search_Directory(szFilename),""))
AfxMessageBox("查找文件完毕!");
else
AfxMessageBox("找不到要查找的文件");
return true;
}
char* CTest_Thread1Dlg::Search_Directory(char* szFilename)
{
long handle;
struct _finddata_t filestruct;
//表示文件(或目录)的信息
//path_search = "";
//表示查找到的路径结果
// 开始查找工作, 找到当前目录下的第一个实体(文件或子目录),
// "*"表示查找任何的文件或子目录, filestruct为查找结果
handle = _findfirst("*", &filestruct);
// 如果handle为-1, 表示当前目录为空, 则结束查找而返回
if((handle == -1))
return false;
// 检查找到的第一个实体是否是一个目录(filestruct.name为其名称)
if( ::GetFileAttributes(filestruct.name) & FILE_ATTRIBUTE_DIRECTORY )
{
// 如果是目录, 则进入该目录并递归调用函数Search_Dirctory进行查找,
// 注意: 如果目录名的首字符为'.'(即为"."或".."), 则不用进行查找
if( filestruct.name[0] != '.' )
{
_chdir(filestruct.name);
Search_Directory(szFilename);
// 查找完毕之后, 返回上一级目录
_chdir("..");
}
//else
// AfxMessageBox("查找当前目录无效");
}
else // 如果第一个实体不是目录, 则检查是否是要查找的文件
{
// stricmp对两字符串进行小写形式的对比, 返回为0表示完全一致
if( !stricmp(filestruct.name, szFilename) )
{
// 先获得当前工作目录的全路径
_getcwd(path_search,_MAX_PATH);
// 再获得文件的完整的路径名(包含文件的名称)
strcat(path_search,"\\");
strcat(path_search,filestruct.name);
//MessageBox(path_search); //输出显示
return path_search;
}
}
// 继续对当前目录中的下一个子目录或文件进行与上面同样的查找
bool flag = false;
while((!(_findnext(handle,&filestruct))&!flag))
{
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);
flag = true;
return path_search;
}
}
}
// 最后结束整个查找工作
_findclose(handle);
return path_search;
}
本文介绍了一种基于C++的文件搜索与路径查找算法,通过遍历指定目录下的所有实体,实现对特定文件的查找,并展示其路径全名。
906

被折叠的 条评论
为什么被折叠?



