首页 > 解决方案 > 找到所需文件后,如何立即停止递归搜索目录?

问题描述

我正在递归搜索具有特定名称的文件的目录结构。我想在找到该文件的第一个实例后立即中断。我怎样才能做到这一点?目前,即使在找到我正在寻找的文件的实例之后,它仍在继续解析其余文件。

async function walkDir(dir: string, callback: Function) {
  for (const f of await fs.readdir(dir)) {
    const dirPath = path.join(dir, f);
    if ((await fs.stat(dirPath)).isDirectory())
      walkDir(dirPath, callback);
    else if (callback(path.join(dir, f)))
      return;
  }

let foundFile = false;
await walkDir(startDir, function (f: string) {
  console.log(f);
  if (path.basename(f) === 'manifest.xml') {
    foundFile = true;
    return;
  }
});

标签: node.jstypescriptrecursionfs

解决方案


最简单的选择可能是从回调中返回true/如果找到值则返回。falsewalkDir

async function walkDir(dir: string, callback: (path: string) => boolean): Promise<boolean> {
    for (const f of await fs.readdir(dir)) {
        const dirPath = path.join(dir, f);
        if ((await fs.stat(dirPath)).isDirectory()) {
            if (await walkDir(dirPath, callback)) {
                return true
            }
        }
        else if (callback(path.join(dir, f))) {
            return true;
        }
    }
    return false;
}


var args= { dir: "" };
(async function () {
    let foundFile = false;
    await walkDir(args.dir, function (f: string) {
        console.log(f);
        if (path.basename(f) === 'manifest.xml') {
            foundFile = true;
            return true;
        }
        return false;
    });
})();

这也可以简化对示例代码中用例的调用:

let foundFile = await walkDir(args.dir, f => path.basename(f) === 'manifest.xml');

推荐阅读