05_Node js 文件管理模块 fs

05_Node js 文件管理模块 fs

一、fs 基础方法:

  • fs.stat 检测是文件还是目录。
  • fs.mkdir 创建目录。
  • fs.writeFile 创建写入文件。
  • fs.appendFile 追加文件。
  • fs.readFile 读取文件(异步)。
  • fs.readFileSync 读取文件(同步)。
  • fs.readdir 读取目录。
  • fs.rename 重命名。
  • fs.rmdir 删除目录。
  • fs.unlink 删除文件。

1、fs.stat:检测是文件还是目录

fs.js

const fs = require("fs");
fs.stat('fs.js', (error, stats) => {
    if (error) {
        console.log(error);
        return false;
    } else {
        console.log(stats);
        console.log(`文件:${stats.isFile()}`); // 文件:true
        console.log(`目录:${stats.isDirectory()}`); // 目录:false

        return false;
    };
});
复制代码

执行 node fs.js。

console.log(stats):
{ dev: 636204,
  mode: 33206,
  nlink: 1,
  uid: 0,
  gid: 0,
  rdev: 0,
  blksize: undefined,
  ino: 1407374883609714,
  size: 242,
  blocks: undefined,
  atime: 2018-12-25T09:14:40.866Z,
  mtime: 2019-01-15T09:18:06.561Z,
  ctime: 2019-01-15T09:18:06.561Z,
  birthtime: 2018-12-25T09:14:40.866Z }

console.log(`文件:${stats.isFile()}`); // 文件:true
console.log(`目录:${stats.isDirectory()}`); // 目录:false
复制代码

补充:

  • stats.isFile() 如果是文件返回 true,否则返回 false。
  • stats.isDirectory() 如果是目录返回 true,否则返回 false。
  • stats.isBlockDevice() 如果是块设备返回 true,否则返回 false。
  • stats.isCharacterDevice() 如果是字符设备返回 true,否则返回 false。
  • stats.isSymbolicLink() 如果是软链接返回 true,否则返回 false。
  • stats.isFIFO() 如果是FIFO,返回true,否则返回 false,FIFO是UNIX中的一种特殊类型的命令管道。
  • stats.isSocket() 如果是 Socket 返回 true,否则返回 false。

2、fs.mkdir:创建目录

fs.js

const fs = require("fs");
fs.mkdir('images', (err) => {
    if (err) {
        console.log(err);
        return false;
    } else {
        console.log("目录创建成功!");
    };
});
复制代码

接收参数:

  • path:将创建的目录路径。
  • mode:目录权限(读写权限),默认 0777。
  • callback:回调,传递异常参数 err。

执行 node fs.js。

会发现目录下多了一个 images 文件夹。

3、fs.rmdir:删除目录

fs.js

const fs = require("fs");
fs.rmdir('images', (err) => {
    if (err) {
        console.log(err);
        return false;
    } else {
        console.log("目录删除成功!");
    };
});
复制代码

执行 node fs.js。

会发现目录下 images 文件夹被删除。

4、fs.writeFile:创建写入文件

fs.js

const fs = require("fs");
fs.writeFile("index.js", "hello NodeJS!", (err) => {
    if (err) {
        console.log(err);
        return false;
    } else {
        console.log("文件写入成功!");
    };
});
复制代码

接收参数:

  • filename (String) 文件名称。
  • data (String | Buffer) 将要写入的内容,可以是字符串或者 buffer 数据。
  • encoding (String) 可选。默认 ‘utf-8’,当 data 是 buffer 时,该值应该为 ignored。
  • mode (Number) 文件读写权限,默认 438。
  • flag (String) 默认值 ‘w’。
  • callback { Function } 回调,传递一个异常参数 err。

执行 node fs.js。

会发现目录下多了一个 index.js 文件夹,并且添加了“hello NodeJS!”的内容。

注意,这样的写入,是清空原文件中的所有数据,然后添加“hello NodeJS!”这句话,即:存在即覆盖,不存在即创建。

5、fs.unlink:删除文件

fs.js

const fs = require("fs");
fs.unlink("index.js", (err) => {
    if (err) {
        console.log(err);
        return false;
    } else {
        console.log("删除成功!");
    };
});
复制代码

执行 node fs.js。

会发现目录下 index.js 文件被删除。

6、fs.appendFile:追加文件

fs.js

const fs = require("fs");
fs.appendFile("index.js", "追加的内容", (err) => {
    if (err) {
        console.log(err);
        return false;
    } else {
        console.log("追加成功!");
    };
});
复制代码

执行 node fs.js。

会发现目录下 index.js 文件后有追加了一段话“追加的内容”。

7、fs.readFile:读取文件

fs.js

const fs = require("fs");
fs.readFile("index.js", (err, data) => {
    if (err) {
        console.log(err);
        return false;
    } else {
        console.log("读取文件成功!");
        console.log(data); // <Buffer 68 65 6c 6c 6f 20 4e 6f 64 65 4a 53 ef bc 81 e8 bf bd e5 8a a0 e7 9a 84 e5 86 85 e5 ae b9>
    };
});
复制代码

执行 node fs.js。

console.log(data) 打印结果:

<Buffer 68 65 6c 6c 6f 20 4e 6f 64 65 4a 53 ef bc 81 e8 bf bd e5 8a a0 e7 9a 84 e5 86 85 e5 ae b9>
复制代码

8、fs.readdir:读取目录

fs.js

const fs = require("fs");
fs.readdir("node_modules", (err, data) => {
    if (err) {
        console.log(err);
        return false;
    } else {
        console.log("读取目录成功!");
        console.log(data); // [ '03_tool_multiply.js', 'my_module' ]
    };
});
复制代码

执行 node fs.js。

console.log(data) 打印结果:

[ '03_tool_multiply.js', 'my_module' ]
复制代码

9、fs.rename:重命名

fs.js

const fs = require("fs");
fs.rename("index.js", "new_index.js", (err) => {
    if (err) {
        console.log(err);
        return false;
    } else {
        console.log("重命名成功!");
    };
});
复制代码

执行 node fs.js。

会发现目录下 index.js 文件被修改为 new_index.js。

10、补充:fs.rename 还可以剪切

fs.js

const fs = require("fs");
fs.rename("new_index.js", "node_modules/new_index.js", (err) => {
    if (err) {
        console.log(err);
        return false;
    } else {
        console.log("剪切成功!");
    };
});
复制代码

执行 node fs.js。

会发现目录下 new_index.js 文件被移动到了 node_modules 目录下。

二、fs 案例

1、判断是否有 upload 目录

fsDemo.js

const fs = require("fs");
fs.stat("upload", (err, stats) => {
    if (err) {
        // 如果没有,创建 upload 目录
        fs.mkdir("upload", (err) => {
            if (err) {
                console.log(err);
                return false;
            } else {
                console.log("创建成功!");
            };
        })
    } else {
        console.log(stats.isDirectory()); // true
        console.log("有 upload 目录,你可以做更多操作!");
    };
});
复制代码

执行 fsDemo.js。

打印结果:

console.log(stats.isDirectory()); // true
有 upload 目录,你可以做更多操作!
复制代码

2、读取目录全部文件

fsDemo.js

const fs = require("fs");
fs.readdir("../05fs/", (err, files) => {
    if (err) {
        console.log(err);
        return false;
    } else {
        console.log(files);
        let filesArr = [];

        (function getFile(i) {
            // 循环结束
            if (i == files.length) {
                // 打印出所有目录
                console.log("目录");
                console.log(filesArr);
                return false;
            };

            // 判断目录是文件还是文件夹
            fs.stat("../05fs/" + files[i], (err, stats) => {
                if (stats.isDirectory()) {
                    filesArr.push(files[i]);
                };
                // 递归调用
                getFile(i + 1);
            });
        })(0);
    };
});
复制代码

执行 fsDemo.js。

打印结果:

[ 'fs.js', 'fsDemo.js', 'fsStream.js', 'upload' ]
目录
[ 'upload' ]
复制代码

三、fs 流

1、fs 流及其读取

首先创建一个 index.js 文件,并添加测试文本。

fsStream.js

const fs = require("fs");
// 流的方式读取文件
const fileReadStream = fs.createReadStream("index.js");
// 读取次数
let count = 0;
// 保存数据
let str = "";
// 开始读取
fileReadStream.on("data", (chunk) => {
    console.log(`${++count} 接收到:${chunk.length}`);
    str += chunk;
});
// 读取完成
fileReadStream.on("end", () => {
    console.log("结束");
    console.log(count);
    console.log(str);
});
// 读取失败
fileReadStream.on("err", (err) => {
    console.log(err);
});
复制代码

执行 fsStream.js。

打印结果:

1 接收到:18
结束
1
fs 流及其读取
复制代码

2、流的写入

fsStream.js

const fs = require("fs");
let data = "存入数据...";
// 创建一个可以写入的流,写入到 index.js
let fileWriteStream = fs.createWriteStream("index.js");
// 开始写入
fileWriteStream.write(data, "utf8");
// 写入完成
fileWriteStream.end();
fileWriteStream.on("finish", () => {
    console.log("写入完成!");
});
复制代码

执行 fsStream.js。

打开 index.js 文件,发现里面内容变成了“存入数据…”。

打印结果:

写入完成!
复制代码

以上我们就通过流的形式进行了读取和写入的操作。


期待您的关注!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/101118.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • Liunx常用命令

    Liunx常用命令Liunx常用命令

  • .NET Core 中的 Generic Host快速使用指南

    .NET Core 中的 Generic Host快速使用指南本文以自己在工作中学习和使用.netcoregeneric-host作一个总结。前言在创建的ASPNETCORE项目中,我们可以在Main()中看见,我们通过IWe…

    2022年10月12日
  • java连接MySQL数据库的驱动jar包

    java连接MySQL数据库的驱动jar包mysql官网:https://dev.mysql.com/步骤1步骤2步骤3步骤4或者直接点击这个链接直接到这个页面https://dev.mysql.com/downloads/connector/j/在这个页面再点击弹出的下拉列表这个点击PlatformIndependent然后点击第二个下载在出现的页面点击Nothanks,juststartmydownload即可下载不用登陆我们只下载就行然后将下载的压缩文件导入idea中即可了!手动截图不易点

  • JAVA Class类与反射

    JAVA Class类与反射关于Class类与Class对象与反射Class类与Class对象Class对象是Class类的实例,类至少包含以下信息,因此class类又可以被解构为如下部分:权限修饰符类名参数化类型(泛型信息)接口Interface注解Annotation字段Field(重点)构造器Constructor(重点)方法Methd(重点)以下图为例:整个.class文件最终都成为字节数组byte[]b,里面的构造器、方法等各个“组件”,其实也是字节。打开Class类的源代码,发现果然如此:

  • 静态路由的基本配置实验总结_三个路由器配置静态路由

    静态路由的基本配置实验总结_三个路由器配置静态路由静态路由的基本配置静态路由配置图如下PC1IP地址:192.168.1.2PC2IP地址:192.168.2.2PC3IP地址:192.168.3.2PC4IP地址:192.168.4.2R1IP地址:f1/0192.168.3.1f0/2192.168.4.1s2/01.1.1.1R2IP地址:f0/0192.168.1.1f1/0192.168.2.1s2/01.1.1.2配置好四台电脑

  • 报错: Failed to install the following Android SDK packages as some licences have not been accepted.

    报错: Failed to install the following Android SDK packages as some licences have not been accepted.导入已有的工程,在build时出现了FailedtoinstallthefollowingAndroidSDKpackagesassomelicenceshavenotbeenaccepted.从此开启有点漫长的脱坑之路。出现这个为在解决后发现主要是两个问题:一个是sdkmanager没有更新;另一个原因是项目配置…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号