内容简介:fs.js执行 node fs.js。fs.js
- 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 文件,发现里面内容变成了“存入数据...”。
打印结果:
写入完成! 复制代码
以上我们就通过流的形式进行了读取和写入的操作。
以上所述就是小编给大家介绍的《05_Node js 文件管理模块 fs》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
罗辑思维:迷茫时代的明白人
罗振宇 / 北京联合出版公司 / 2015-9 / 42
编辑推荐 1、 罗振宇,自媒体视频脱口秀《罗辑思维》主讲人,互联网知识型社群试水者,资深媒体人和传播专家。曾任CCTV《经济与法》《对话》制片人等。2012年底打造知识型视频脱口秀《罗辑思维》。半年内,由一款互联网自媒体视频产品,逐渐延伸成长为全新的互联网社群品牌。 他对商业和互联网的独到见解,影响了互联网一代的知识结构和对互联网的认识:人类正在从工业化时代进入互联网时代。新的时代将彻......一起来看看 《罗辑思维:迷茫时代的明白人》 这本书的介绍吧!