【Node.js】内置模块FileSystem的保姆级入门讲解

作者:CSDN-PleaSure乐事

欢迎大家阅读我的博客 希望大家喜欢

使用环境:Vscode

本文代码都经由博主PleaSure乐事实操后得出,可以放心使用。

1.FileSystem介绍

Node.js 的 fs(filesystem)模块是一个核心模块,提供了与文件系统进行交互的功能。它允许你读取、写入、删除和管理文件和目录。fs 模块提供了同步和异步两种方式来执行文件操作,使得编写者可以根据具体需求选择合适的方法。

2.FileSystem基本操作介绍

在正式进行FileSystem前,我们需要创建一个js文件,并对fs模块进行导入:

javascript 复制代码
//方法一
import fs from 'fs'
//方法二
const fs = require('fs');

2.1创建目录

如果我们想要创建目录,我们仅需要使用mkdir即可,fs.promises.mkdir会进行目录创建,其中recursive是用来控制是否允许创建多级目录,若设置为true则允许创建多级目录,反之false则不能创建。

javascript 复制代码
const createDir = async (path) => {
    try {
      await fs.promises.mkdir(path, { recursive: true }) // recursive: true 允许递归创建多级目录
      console.log("目录创建成功")
    } catch (err) {
      console.error(`目录创建失败: ${err}`)
    }
  }
let dir = "PleaSure/csdn/"
createDir(dir) //创建多级目录

如下图所示,我们已经成功创建了一个多级目录:

2.2写入文件

如果我们要写入文件,我们需要使用writeFile来处理,fs.promises.writeFile会进行文件写入。但是需要注意,我们最好添加path.join来处理不同电脑间路径不一致的情况,在 Windows 系统中,路径分隔符通常是反斜杠(\),而在 Unix 和类 Unix 系统(如 Linux 和 macOS)中,路径分隔符是正斜杠(/)。

javascript 复制代码
const writeFile = async (filePath, content) => {
  try {
    await fs.promises.writeFile(filePath, content);
    console.log("文件写入成功");
  } catch (err) {
    console.error(`文件写入失败: ${err}`);
  }
};

// 定义目录和文件路径
let dir = "PleaSure/csdn/";
let name = "web.txt";

let filePath = path.join(dir, name); // 使用 path.join 来处理路径

// 创建目录
createDir(dir).then(() => {
  // 写入文件
  writeFile(filePath, content);
});

但是需要注意,这里的写入文件是会覆盖的!

2.3追加文件

追加文件则直接使用appendFile即可,fs.promises.appendFile会进行文件追加,内容将被写在文件最后:

javascript 复制代码
const appendToFile = async (filePath, content) => {
    try {
      await fs.promises.appendFile(filePath, content);
      console.log("内容追加成功");
    } catch (err) {
      console.error(`内容追加失败: ${err}`);
    }
  };
  
  // 定义目录和文件路径
  let dir = "PleaSure/csdn/";
  let name = "web.txt";
  let filePath = path.join(dir, name); // 使用 path.join 来处理路径
  
  // 创建目录
  createDir(dir).then(() => {
    // 追加内容到文件
    appendToFile(filePath, "pleasure\n"); // 追加内容并换行
  });

2.4读取文件

如果想要读取文件,我们增加readFIle即可,fs.promises.readFile会完成文件读取,输出文件内容:

javascript 复制代码
const readFile = async (filePath) => {
    try {
      const data = await fs.promises.readFile(filePath, 'utf8');
      console.log("文件内容:");
      console.log(data);
    } catch (err) {
      console.error(`文件读取失败: ${err}`);
    }
  };

2.5检查文件或目录是否存在

我们可以使用access来判断文件或目录是否存在,fs.promises.access会完成检查,从而判断下一步操作怎么办,例如创建新的目录等等:

javascript 复制代码
const checkDirExists = async (dirPath) => {
  try {
    await fs.promises.access(dirPath, fs.constants.F_OK);
    console.log(`目录 ${dirPath} 存在`);
    return true;
  } catch (err) {
    console.log(`目录 ${dirPath} 不存在`);
    return false;
  }
};

检查目录或文件是否存在可以帮助我们判断是否需要进行新建文件或目录操作,防止有重名等情况的发生:

javascript 复制代码
checkDirExists(dir).then((exists) => {
  if (!exists) {
    // 如果目录不存在,则创建目录
    return createDir(dir);
  }
  return Promise.resolve(); // 目录已存在,直接返回一个 resolved 的 Promise
}).then(() => {
  // 写入文件
  return writeFile(filePath, content);
}).then(() => {
  // 追加内容到文件
  return appendToFile(filePath, "pleasure\n"); // 追加内容并换行
}).then(() => {
  // 读取文件
  return readFile(filePath);
});

2.6获取目录详细信息

使用stat可以来获取目录详细信息,例如创建时间、修改时间、大小等,我们使用birthtime等即可完成相应信息的调取:

javascript 复制代码
const getDirInfo = async (dirPath) => {
  try {
    const stats = await fs.promises.stat(dirPath);
    if (stats.isDirectory()) {
      console.log(`目录 ${dirPath} 的详细信息:`);
      console.log(`- 大小: ${stats.size} 字节`);
      console.log(`- 创建时间: ${stats.birthtime}`);
      console.log(`- 修改时间: ${stats.mtime}`);
      console.log(`- 访问时间: ${stats.atime}`);
      console.log(`- 是否为目录: ${stats.isDirectory()}`);
      console.log(`- 是否为文件: ${stats.isFile()}`);
      console.log(`- 是否为符号链接: ${stats.isSymbolicLink()}`);
    } else {
      console.log(`${dirPath} 不是一个目录`);
    }
  } catch (err) {
    console.error(`无法获取目录 ${dirPath} 的信息: ${err}`);
  }
};

最终可以得到这样的效果:

2.7文件或目录重命名

入伏哦我们想要完成目录或文件重命名,我们可以使用rename就可以达到效果,fs.promises.rename为完整写法:

javascript 复制代码
const renameFileOrDir = async (oldPath, newPath) => {
    try {
      await fs.promises.rename(oldPath, newPath);
      console.log(`重命名成功: ${oldPath} -> ${newPath}`);
    } catch (err) {
      console.error(`重命名失败: ${err}`);
    }
  };

此时我们可以看到文件名已经被修改了:

2.8删除文件

若想要删除文件,我们直接调用unlink即可完成,fs.promises.unlink会帮助进行文件删除:

javascript 复制代码
const deleteFile = async (filePath) => {
  try {
    await fs.promises.unlink(filePath);
    console.log(`文件删除成功: ${filePath}`);
  } catch (err) {
    console.error(`文件删除失败: ${err}`);
  }
};

此时文件也已经被顺利删除了。

2.9删除目录

如果我们想要删除整个目录,可以使用 fs.promises.rmdir 方法来删除空目录,或者使用 fs.promises.rm 方法来删除非空目录。fs.promises.rm 方法提供了更多的选项,比如递归删除目录及其内容。:

javascript 复制代码
const deleteDir = async (dirPath) => {
  try {
    await fs.promises.rm(dirPath, { recursive: true, force: true });
    console.log(`目录删除成功: ${dirPath}`);
  } catch (err) {
    console.error(`目录删除失败: ${err}`);
  }
};

此时想要删除的目录也已经被删掉了。

3.最终结果:

此时查看控制台,可以看到如下结果,我们从头到尾,从创建到删除的每一步,都顺利执行:

完成每一步操作的代码都可以在文章中获得,若有需要欢迎收藏文章,反复擦写,感谢您的阅读!

作者:CSDN-PleaSure乐事

希望我的博客对您有帮助,也希望在对您有帮助时您可以为我留下点赞收藏与关注,这对我真的很重要,谢谢!

相关推荐
光影少年10 分钟前
vue2与vue3的全局通信插件,如何实现自定义的插件
前端·javascript·vue.js
Rattenking15 分钟前
React 源码学习01 ---- React.Children.map 的实现与应用
javascript·学习·react.js
~甲壳虫23 分钟前
说说webpack中常见的Loader?解决了什么问题?
前端·webpack·node.js
~甲壳虫26 分钟前
说说webpack proxy工作原理?为什么能解决跨域
前端·webpack·node.js
熊的猫1 小时前
JS 中的类型 & 类型判断 & 类型转换
前端·javascript·vue.js·chrome·react.js·前端框架·node.js
别拿曾经看以后~3 小时前
【el-form】记一例好用的el-input输入框回车调接口和el-button按钮防重点击
javascript·vue.js·elementui
川石课堂软件测试3 小时前
性能测试|docker容器下搭建JMeter+Grafana+Influxdb监控可视化平台
运维·javascript·深度学习·jmeter·docker·容器·grafana
JerryXZR3 小时前
前端开发中ES6的技术细节二
前端·javascript·es6
problc4 小时前
Flutter中文字体设置指南:打造个性化的应用体验
android·javascript·flutter
Gavin_9154 小时前
【JavaScript】模块化开发
前端·javascript·vue.js