Node中的fs模块

1.fs.stat检测是文件还是目录
2.fs.mkdir创建目录
3.fs.writeFile创建写入文件
4.fs.appendFile追加文件
5.fs.readFile 读取文件
6.fs.readdir读取目录
7.fs.rename重命名
8.fs.rmdir删除目录
9.fs.unlink 删除文件

  1. fs.stat 检测是文件还是目录
const fs = require('fs')

 fs.stat('./html', function(err, data) {
     if(err) {
         console.log(err)
         return
     }

     console.log(`是文件${data.isFile()}`)
     console.log(`是目录${data.isDirectory()}`)
 })

在这里插入图片描述

  1. fs.mkdir 创建目录
const fs = require('fs')
fs.mkdir('./css2', function (err) {
    if (err) {
        console.log(err)
        return
    }
    console.log('创建成功')
})

在这里插入图片描述

  1. fs.writeFile 创建写入文件
const fs = require('fs')
fs.writeFile('./html/index.html', '你好nodejs', function (err) {
     if (err) {
         console.log(err)
         return
     }
     console.log('创建写入文件成功')
})

在这里插入图片描述
在这里插入图片描述

  1. fs.appendFile 追加文件
const fs = require('fs')
fs.appendFile('./css/base.css', 'body{color: red}', function (err) {
    if (err) {
        console.log(err)
        return
    }
    console.log('appendFile成功')
})

在这里插入图片描述
在这里插入图片描述

5.fs.readFile 读取文件

const fs = require('fs')
fs.readFile('./html/index.html', function (err, data) {
      if (err) {
          console.log(err)
          return
      }
      console.log(data)
      console.log(data.toString())
 })

在这里插入图片描述

6.fs.readdir 读取目录

const fs = require('fs') 
fs.readdir('./html', function (err, data) {
    if (err) {
        console.log(err)
        return
    }
    console.log(data)
})

在这里插入图片描述

7.fs.rename 重命名

const fs = require('fs')

fs.rename('./css/base.css', './css/index.css' ,function (err) {
    if (err) {
        console.log(err)
        return
    }
    console.log('重命名成功')
})

在这里插入图片描述

const fs = require('fs')
fs.rename('./css/index.css', './html/base.css' ,function (err) {
    if (err) {
        console.log(err)
        return
    }
    console.log('移动文件成功')
})

在这里插入图片描述
8. fs.rmdir 删除目录

const fs = require('fs')
fs.rmdir('./aaa',function (err) {
    if (err) {
        console.log(err)
        return
    }
    console.log('删除目录成功')
})

在这里插入图片描述

  1. fs.unlink 删除文件
const fs = require('fs')
fs.unlink('./aaa/index.html',function (err) {
    if (err) {
        console.log(err)
        return
    }
    console.log('删除文件成功')
})

在这里插入图片描述

案例1:判断服务器上面有没有upload目录,如果没有就创建这个目录,如果有的话不做操作
// 判断服务器上面有没有upload目录,如果没有就创建这个目录,如果有的话不做操作


const fs = require('fs')
var path = './upload'

fs.stat(path, function(err, data) {
    if(err) {
        // 执行创建目录
        mkdir(path)
        return
    }
    if(data.isDirectory()) {
        console.log('upload目录已存在')
    }else {
        // 首先删除文件,再去执行创建目录
        fs.unlink(path, function(err) {
            if(!err) {
                mkdir(path)
            }else {
                console.log('请检查传入的路径是否正确')
            }
        })
        

    }
})


function mkdir(dir) {
    fs.mkdir(dir, function(err) {
        if(err) {
            console.log(err)
            return
        }
    })
}
案例2: wwwroot 文件夹下面有img css js 以及index.html, 找出wwwroot目录下的所有的目录
// wwwroot 文件夹下面有img css js 以及index.html, 找出wwwroot目录下的所有的目录

const fs = require('fs')

/* var path = './wwwroot'
var dirArr = []
fs.readdir(path, function(err, data) {
    if(err) {
        console.log(err)
        return
    }

    console.log(data)
    for(var i=0; i<data.length; i++) {
        fs.stat(path + '/' +data[i], function(error,stats) {
            if(stats.isDirectory()) {
                dirArr.push(data[i])
            }
        })
    }
    console.log(dirArr)
})

 */

var path = './wwwroot'
var dirArr = []
fs.readdir(path, function (err, data) {
    if (err) {
        console.log(err)
        return
    }

    (function getDir(i) {
        if (i == data.length) {
            //执行完成
            console.log(dirArr)
            return
        }

        fs.stat(path + '/' + data[i], function (error, stats) {
            if (stats.isDirectory()) {
                dirArr.push(data[i])
            }
            getDir(i + 1)
        })
    })(0)
})


使用函数闭包解决异步方法执行后拿不到结果的问题:
在这里插入图片描述

10. 以流的方式读取文件

在这里插入图片描述

11. 以流的方式写入文件

在这里插入图片描述
在这里插入图片描述

12. 管道流

管道提供了一个输出流到输入流的机制。通常我们用于从一个流中获取数据并将数据传 递到另外一个流中。
在这里插入图片描述
如上面的图片所示,我们把文件比作装水的桶,而水就是文件里的内容,我们用一根管子(pipe)连接两个桶使得水从一个 桶流入另一个桶,这样就慢慢的实现了大文件的复制过程。 以下实例我们通过读取一个文件内容并将内容写入到另外一个文件中。
在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值