文件夹的遍历扫描

用windows的API实现文件夹的遍历扫描的程序
使用到的API:
FindFirstFile
FindNextFile
FindClose
主要用到的结构:
WIN32_FIND_DATA
在msdn都有详细的说明。这里也简要说明一下:
HANDLE WINAPI FindFirstFile(
  __in          LPCTSTR lpFileName, //要查找的文件路径
  __out         LPWIN32_FIND_DATA lpFindFileData//保存文件结构的指针
);
查找对应的路径,如果查找返回查找的句柄,然后我们可以通过该句柄去查找下一个和关闭这个句柄。
如果查找失败,则返回(INVALED_HANDLE_VALUE)(-1),可以通过GetLastError();来得到他的错误类型。(貌似我都没有这么做过。不过对于严谨的程序员们,可能很重要,不过这个也是写给自己看的,就不考虑那么多了。哈哈)
注意:查找第一个的时候,他不仅返回了查找的句柄,他也把第一个的文件信息保存在lpFindFileData里面了。所以这个也是要处理的。
WIN32_FIND_DATA的结构就是一个结构提,在这里我智慧用到cFileName(文件名)和dwFileAttributes(文件属性)两个域。

BOOL WINAPI FindNextFile(
  __in          HANDLE hFindFile, //查找的文件句柄
  __out         LPWIN32_FIND_DATA lpFindFileData//保存文件结构的指针
);

他就是在文件句柄的情况下查找下一个文件。并将文件信息保存在lpFindFileData中。成功返回true,失败返回false(就是没有下一个了)

BOOL WINAPI FindClose(
  __in_out      HANDLE hFindFile
);
就是关闭文件句柄咯,没有什么好说的哈。

要试用的函数介绍完毕。主要的思路:

查找他是要给文件路径的。对了,只给文件夹路径还不可以,必须还要加上//*.*等查找的过滤关键字。否则他只找到文件夹,呵呵。过滤的关键字也可是?*.*?什么什么的组合都可以可以例如:abc?f*.t?t*这样。

确定好文件路径之后,调用FindFirstFile函数来查找,记得要检查他是否成功哦!还有就是如果成功,第一个查找到的信息已经保存在lpFindFileData里面了。

因为第一个信息已经保存在里面了,而下面还要查找很多下一个,这里必须用到循环了。那么用什么循环呢。看FindNextFile()就知道要用while,不过且慢,上面不是有一个还要处理嘛。难道要先处理完了再用while?no,我们用do while;这样就可以先处理,然后在循环,直到查找完毕。(之所以写这些是因为我开始是用的WHILE发现总是少一个,后来才知道first的时候已经有一个了,所以才用了do while哎。。)

循环体:出来单个查找的内容,这里有几个要注意的是文件夹里面有".." 和"."两个查找到的不用处理,我也不知道他是干什么的,是网上查到的。呵呵。然后就是判断是否为文件夹(if(findFileData.dwAttributes & FILE_ATTRIBUTE_DIRECTORY));。否则就不是文件夹,是文件。
然后在分开处理他们。。

最后不要忘了要关闭句柄。FileClose(hFind);

主要思路就是这些了。呵呵。。源代码奉上:

 

 1  #include<iostream>
 2  #include <Windows.h>
 3  #include <string>
 4  #include <assert.h>
 5 
 6  typedef bool (*FindProc)(const char*  chFinleName);
 7
 
 8  //遍历文件夹,chFolderPath为要遍历的文件夹路径。chFilter为遍历文件夹的过滤器,例如*.txt等
 9  bool FindFolder(const char* chFolderPath, const char* chFilter, bool  bFindFolder, FindProc pFindProc)
10
  {
11
      assert(pFindProc);
12
      int nPathLen = strlen(chFolderPath) +  MAX_PATH;
13
      char* pChPath = new char [nPathLen];
14
      sprintf_s(pChPath, nPathLen, "%s//%s" , chFolderPath, chFilter);
15
      WIN32_FIND_DATA fileFindData;
16
      HANDLE hFind = ::FindFirstFile(pChPath, &fileFindData);            //找到第一个
17      
18
      if (hFind == INVALID_HANDLE_VALUE)        //如果没有找到相关的文件信息,返回false
19      {
20
          delete pChPath;
21
          return false ;
22
      }
23
 
24      //处理之后查找下一个,直到都找完
25      do  
26
      {
27
          if (fileFindData.cFileName[0] == '.' )
28
          {
29
              continue;            //因为文件夹开始有"."和".."两个目录,要过滤掉
30          }
31
 
32          sprintf_s(pChPath, nPathLen, "%s//%s", chFolderPath, fileFindData.cFileName);    // 文件的完整路径
33
 
34          //如果要查找递归查找文件夹
35          if (bFindFolder && (fileFindData.dwFileAttributes &  FILE_ATTRIBUTE_DIRECTORY))
36
          {
37
              FindFolder(pChPath, chFilter, bFindFolder, pFindProc);            //递归调用来查找他的子目录
38          }
39
 
40          //如果是文件
41          pFindProc(pChPath);
42
 
43      }while (::FindNextFile(hFind, & fileFindData)); 
44
 
45      FindClose(hFind);                //关闭查找句柄
46      delete pChPath;    
47
      return true ;
48
  }
49
 
50  bool PrintFiles(const char*  chFileName)
51
  {
52
      printf("%s/n" , chFileName);
53
      return true ;
54
  }
55
  int  main()
56
  {
57
      
58
      FindFolder("test", "*.*", true, & PrintFiles);
59
      getchar();
60
 
61      return 0 ;
62
  }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值