<legend id='N3sjm'><style id='N3sjm'><dir id='N3sjm'><q id='N3sjm'></q></dir></style></legend>

    <small id='N3sjm'></small><noframes id='N3sjm'>

  1. <i id='N3sjm'><tr id='N3sjm'><dt id='N3sjm'><q id='N3sjm'><span id='N3sjm'><b id='N3sjm'><form id='N3sjm'><ins id='N3sjm'></ins><ul id='N3sjm'></ul><sub id='N3sjm'></sub></form><legend id='N3sjm'></legend><bdo id='N3sjm'><pre id='N3sjm'><center id='N3sjm'></center></pre></bdo></b><th id='N3sjm'></th></span></q></dt></tr></i><div id='N3sjm'><tfoot id='N3sjm'></tfoot><dl id='N3sjm'><fieldset id='N3sjm'></fieldset></dl></div>

    • <bdo id='N3sjm'></bdo><ul id='N3sjm'></ul>
    1. <tfoot id='N3sjm'></tfoot>
    2. 使用 C++ MFC 进行递归文件搜索?

      时间:2023-08-03
    3. <tfoot id='bd27K'></tfoot>
      • <bdo id='bd27K'></bdo><ul id='bd27K'></ul>
      • <i id='bd27K'><tr id='bd27K'><dt id='bd27K'><q id='bd27K'><span id='bd27K'><b id='bd27K'><form id='bd27K'><ins id='bd27K'></ins><ul id='bd27K'></ul><sub id='bd27K'></sub></form><legend id='bd27K'></legend><bdo id='bd27K'><pre id='bd27K'><center id='bd27K'></center></pre></bdo></b><th id='bd27K'></th></span></q></dt></tr></i><div id='bd27K'><tfoot id='bd27K'></tfoot><dl id='bd27K'><fieldset id='bd27K'></fieldset></dl></div>

              <legend id='bd27K'><style id='bd27K'><dir id='bd27K'><q id='bd27K'></q></dir></style></legend>

                <small id='bd27K'></small><noframes id='bd27K'>

                  <tbody id='bd27K'></tbody>
                本文介绍了使用 C++ MFC 进行递归文件搜索?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

                问题描述

                使用 C++ 和 MFC 递归搜索文件的最简洁方法是什么?

                What is the cleanest way to recursively search for files using C++ and MFC?

                这些解决方案中的任何一个都提供通过一次通过使用多个过滤器的能力吗?我想使用 CFileFind 我可以过滤 *.* 然后编写自定义代码以进一步过滤到不同的文件类型.是否提供内置的多个过滤器(即 *.exe、*.dll)?

                Do any of these solutions offer the ability to use multiple filters through one pass? I guess with CFileFind I could filter on *.* and then write custom code to further filter into different file types. Does anything offer built-in multiple filters (ie. *.exe,*.dll)?

                刚刚意识到我所做的一个明显假设使我之前的 EDIT 无效.如果我尝试使用 CFileFind 进行递归搜索,我必须使用 *.* 作为我的通配符,否则将无法匹配子目录并且不会发生递归.因此,无论如何都必须单独处理对不同文件扩展名的过滤.

                Just realized an obvious assumption that I was making that makes my previous EDIT invalid. If I am trying to do a recursive search with CFileFind, I have to use *.* as my wildcard because otherwise subdirectories won't be matched and no recursion will take place. So filtering on different file-extentions will have to be handled separately regardless.

                推荐答案

                使用 CFileFind.

                看看这个示例来自MSDN:

                Take a look at this example from MSDN:

                void Recurse(LPCTSTR pstr)
                {
                   CFileFind finder;
                
                   // build a string with wildcards
                   CString strWildcard(pstr);
                   strWildcard += _T("\*.*");
                
                   // start working for files
                   BOOL bWorking = finder.FindFile(strWildcard);
                
                   while (bWorking)
                   {
                      bWorking = finder.FindNextFile();
                
                      // skip . and .. files; otherwise, we'd
                      // recur infinitely!
                
                      if (finder.IsDots())
                         continue;
                
                      // if it's a directory, recursively search it
                
                      if (finder.IsDirectory())
                      {
                         CString str = finder.GetFilePath();
                         cout << (LPCTSTR) str << endl;
                         Recurse(str);
                      }
                   }
                
                   finder.Close();
                }
                

                这篇关于使用 C++ MFC 进行递归文件搜索?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持html5模板网!

                上一篇:通过泛型 lambda 理解 Y Combinator 下一篇:递归地传递一个字符串而不需要娱乐

                相关文章

                最新文章

                  <legend id='kJa8l'><style id='kJa8l'><dir id='kJa8l'><q id='kJa8l'></q></dir></style></legend>

                  1. <tfoot id='kJa8l'></tfoot>
                  2. <i id='kJa8l'><tr id='kJa8l'><dt id='kJa8l'><q id='kJa8l'><span id='kJa8l'><b id='kJa8l'><form id='kJa8l'><ins id='kJa8l'></ins><ul id='kJa8l'></ul><sub id='kJa8l'></sub></form><legend id='kJa8l'></legend><bdo id='kJa8l'><pre id='kJa8l'><center id='kJa8l'></center></pre></bdo></b><th id='kJa8l'></th></span></q></dt></tr></i><div id='kJa8l'><tfoot id='kJa8l'></tfoot><dl id='kJa8l'><fieldset id='kJa8l'></fieldset></dl></div>
                  3. <small id='kJa8l'></small><noframes id='kJa8l'>

                      <bdo id='kJa8l'></bdo><ul id='kJa8l'></ul>