检索文件 (未完善 待续!)

 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;
 }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值