Node.js 使用递归实现遍历文件夹中所有文件


Posted in Javascript onSeptember 18, 2017

如标题所示,遍历文件夹下的所有文件,主要功能如下:

传入一个路径,读取路径里面所有的文件
遍历读取的文件,判断当前文件是文件还是文件夹
当前目录为文件,打印出当前文件绝对路径
当前目录为文件夹,获取文件夹路径,继续读取路径下文件
遍历完目录中的所有文件为止
代码中用到的几个方法

path.resolve(path)

一个路径或路径片段解析成一个绝对路径,返回解析后的路径字符串
fs.readdir(path[,option],callback)

读取目录下面的文件,返回目录下的文件列表对象,如果传入的是个文件,返回这个文件

fs.stat(path,callback)

获取文件信息对象Stats,包括文件大小,gid等信息

stats.isFile()

文件信息对象Stats的一个方法,判断当前文件是不是一个文件

stats.isDirectory()

文件信息对象Stats的一个方法,判断当前文件是不是一个文件夹

代码和注释如下:

var fs = require('fs');
var path = require('path');

//解析需要遍历的文件夹,我这以E盘根目录为例
var filePath = path.resolve('E:');

//调用文件遍历方法
fileDisplay(filePath);

/**
 * 文件遍历方法
 * @param filePath 需要遍历的文件路径
 */
function fileDisplay(filePath){
  //根据文件路径读取文件,返回文件列表
  fs.readdir(filePath,function(err,files){
    if(err){
      console.warn(err)
    }else{
      //遍历读取到的文件列表
      files.forEach(function(filename){
        //获取当前文件的绝对路径
        var filedir = path.join(filePath,filename);
        //根据文件路径获取文件信息,返回一个fs.Stats对象
        fs.stat(filedir,function(eror,stats){
          if(eror){
            console.warn('获取文件stats失败');
          }else{
            var isFile = stats.isFile();//是文件
            var isDir = stats.isDirectory();//是文件夹
            if(isFile){
              console.log(filedir);
            }
            if(isDir){
              fileDisplay(filedir);//递归,如果是文件夹,就继续遍历该文件夹下面的文件
            }
          }
        })
      });
    }
  });
}

运行结果为:

E:\jars\spring-framework-4.2.9.RELEASE\docs\javadoc-api\org\springframework\cache\interceptor\AbstractCacheInvoker.html
E:\jars\spring-framework-4.2.9.RELEASE\docs\javadoc-api\org\springframework\cache\interceptor\AbstractCacheResolver.html
E:\jars\spring-framework-4.2.9.RELEASE\docs\javadoc-api\org\springframework\cache\interceptor\BasicOperation.html
E:\jars\spring-framework-4.2.9.RELEASE\docs\javadoc-api\org\springframework\cache\interceptor\CacheableOperation.html
E:\jars\spring-framework-4.2.9.RELEASE\docs\javadoc-api\org\springframework\cache\interceptor\BeanFactoryCacheOperationSourceAdvisor.html
E:\jars\spring-framework-4.2.9.RELEASE\docs\javadoc-api\org\springframework\cache\interceptor\AbstractFallbackCacheOperationSource.html
E:\jars\spring-framework-4.2.9.RELEASE\docs\javadoc-api\org\springframework\cache\interceptor\CacheAspectSupport.CacheOperationContext.html
E:\jars\spring-framework-4.2.9.RELEASE\docs\javadoc-api\org\springframework\cache\interceptor\CacheAspectSupport.html
E:\jars\spring-framework-4.2.9.RELEASE\docs\javadoc-api\org\springframework\cache\interceptor\CacheAspectSupport.CacheOperationMetadata.html
E:\jars\spring-framework-4.2.9.RELEASE\docs\javadoc-api\org\springframework\cache\interceptor\CacheErrorHandler.html
E:\jars\spring-framework-4.2.9.RELEASE\docs\javadoc-api\org\springframework\cache\interceptor\CacheEvictOperation.html
E:\jars\spring-framework-4.2.9.RELEASE\docs\javadoc-api\org\springframework\cache\interceptor\CacheInterceptor.html
E:\jars\spring-framework-4.2.9.RELEASE\docs\javadoc-api\org\springframework\cache\interceptor\CacheOperation.html
E:\jars\spring-framework-4.2.9.RELEASE\docs\javadoc-api\org\springframework\cache\interceptor\CacheOperationInvocationContext.html
E:\jars\spring-framework-4.2.9.RELEASE\docs\javadoc-api\org\springframework\cache\interceptor\CacheOperationInvoker.html
············

到这Node.js 遍历文件夹的实现方法就结束了,希望大家以后多多支持三水点靠木。

Javascript 相关文章推荐
JS中剪贴板兼容性、判断复制成功或失败
Mar 09 Javascript
javascript学习笔记(九) js对象 设计模式
Jun 19 Javascript
jquery ajax方式直接提交整个表单核心代码
Aug 15 Javascript
怎么判断js脚本加载完成
Feb 28 Javascript
JavaScript淡入淡出渐变简单实例
Aug 06 Javascript
jQuery使用$.ajax进行异步刷新的方法(附demo下载)
Dec 04 Javascript
初识angular框架后的所思所想
Feb 19 Javascript
Bootstrap与KnockoutJs相结合实现分页效果实例详解
May 03 Javascript
AngularJs点击状态值改变背景色的实例
Dec 18 Javascript
webpack4 + react 搭建多页面应用示例
Aug 03 Javascript
js设置默认时间跨度过程详解
Jul 17 Javascript
Node.JS 循环递归复制文件夹目录及其子文件夹下的所有文件
Sep 18 #Javascript
为什么我们要做三份 Webpack 配置文件
Sep 18 #Javascript
分析javascript中9 个常见错误阻碍你进步
Sep 18 #Javascript
十个免费的web前端开发工具详细整理
Sep 18 #Javascript
Redux 和 Mobx的选择问题:让你不再困惑!
Sep 18 #Javascript
HTML5开发Kinect体感游戏的实例应用
Sep 18 #Javascript
聊聊那些使用前端Javascript实现的机器学习类库
Sep 18 #Javascript
You might like
老机欣赏|中国60年代精品收音机
2021/03/02 无线电
php cookis创建实现代码
2009/03/16 PHP
GBK的页面输出JSON格式的php函数
2010/02/16 PHP
php whois查询API制作方法
2011/06/23 PHP
file_get_contents获取不到网页内容的解决方法
2013/03/07 PHP
浅谈COOKIE和SESSION区别
2015/07/19 PHP
php+html5实现无刷新图片上传教程
2016/01/22 PHP
javascript cookie解码函数(兼容ff)
2008/03/17 Javascript
ASP.NET jQuery 实例14 在ASP.NET form中校验时间范围
2012/02/03 Javascript
jQuery写fadeTo示例代码
2014/02/21 Javascript
JS弹性运动实现方法分析
2016/12/15 Javascript
Angular.js中处理页面闪烁的方法详解
2017/03/09 Javascript
Vue框架中正确引入JS库的方法介绍
2017/07/30 Javascript
如何解决.vue文件url引用文件的问题
2019/01/18 Javascript
Vue CLI3基础学习之pages构建多页应用
2019/06/02 Javascript
微信小程序解析富文本过程详解
2019/07/13 Javascript
如何通过shell脚本自动生成vue文件详解
2019/09/10 Javascript
如何使用RoughViz可视化Vue.js中的草绘图表
2021/01/30 Vue.js
python实现在控制台输入密码不显示的方法
2015/07/02 Python
Python 通配符删除文件的实例
2018/04/24 Python
python assert的用处示例详解
2019/04/01 Python
python logging模块的使用总结
2019/07/09 Python
python如何通过闭包实现计算器的功能
2020/02/22 Python
pycharm永久激活超详细教程
2020/10/29 Python
Python获取android设备cpu和内存占用情况
2020/11/15 Python
python中random模块详解
2021/03/01 Python
css sprite简单实例
2016/05/23 HTML / CSS
销售行业个人求职自荐信
2013/09/25 职场文书
大学生两会精神学习心得体会
2014/03/10 职场文书
工作疏忽、懈怠的检讨书
2014/09/11 职场文书
2014年助理政工师工作总结
2014/12/19 职场文书
2014会计年终工作总结
2014/12/20 职场文书
2015年度培训工作总结范文
2015/04/02 职场文书
煤矿隐患排查制度
2015/08/05 职场文书
优秀班干部主要事迹材料
2015/11/04 职场文书
求职信:求职应该注意的问题
2019/04/24 职场文书