如何解决使用Node.js中的搜索模式搜索成千上万个文件夹
所以,让我解释一下。我正在使用Node应用程序,该应用程序必须访问文件夹中的某些确定文件。但是问题从这里开始;有超过一千个这样的文件夹,它们以text / html格式存储了独特的数据,并且将来还会增长。因此,我决定创建一个可以搜索文件夹的搜索部分。但是我被困在这里。我本来打算将所有文件夹的名称列出在一个数组中并对其进行处理,但是我很快意识到这是一个坏主意。超级慢!结构:
app.js
public
searchable
folder-1
unqiue.html
folder-2
unique2.html
folder-3
unique3.html
...
而且这种情况一直持续下去。我是Node.js的新手,正在努力使事情变得正确。所以,有什么办法可以实现这一目标。任何新的想法表示赞赏。预先感谢。
解决方法
与其保存文件夹数组并从该数组中检索文件,不如说。
使用fs
库和cache
动态地将每个引用根目录的文件的路径保存为数组。
const fs = require('fs');
let filePathArr = [];
getfilePathArray('src');
function getfilePathArray(path) {
fs.readdir(path,(err,files) => {
if (files) {
files.forEach(file => {
if (file.indexOf('.') !== -1) {
filePathArr.push(path + '/' + file);
} else {
getfilePathArray(path + '/' + file);
}
});
}
console.log(filePathArr);
});
}
然后,您可以从缓存的数组中搜索唯一的文件名unique.html
const searchedPath = filePathArr.find(path=>path.indexOf('unique.html') !== -1)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。