文件I/O
一、文件I/O
1.I/O:Input/Output
1.对外部设备的输入输出
2.外部设备
3.速度
IO的速度往往低于内存和CPU的交互速度。
2.fs模块
1.fs.readFile
异步地读取文件的全部内容。
const fs = require("fs");
const path = require("path");
const filename = path.resolve(__dirname, "./read.txt");
fs.readFile(filename, (err, content) => {
console.log(content.toString("utf-8"));//不使用utf-8将读取数字编码
});
console.log(1);
该方法为异步。
或者传递第二参数也可以读取出数据。
const filename = path.resolve(__dirname, "./read.txt");
fs.readFile(filename, "utf-8", (err, content) => {
console.log(content);
});
同步执行的方法
const content = fs.readFileSync(filename, "utf-8");
console.log(content);
console.log(1);
Sync函数是同步的,会导致JS运行阻塞,极其影响性能
通常,在程序启动时运行有限的次数即可
async function test() {
const content = await fs.promises.readFile(filename, "utf-8");
console.log(content);
}
test();
console.log(1);
2.fs.writeFile
向文件写入内容。
const fs = require("fs");
const os = require("os");
const path = require("path");
const filename = path.resolve(__dirname, "./write.txt");
async function test() {
await fs.promises.writeFile(filename, os.EOL+"阿斯顿发发放到发", {
flag: "a" //追加内容
});
}
test();
这里使用第三参数flag: "a"
表示追加写入。
使用os.EOL
代表换行,window系统也可\n
表示。
如果写入的文件不存在,那么会创建文件,如果写入的文件的上级目录不存在,则报错。
也可以使用Buffer写入。
async function test() {
const buffer = Buffer.from("abcde", "utf-8");
await fs.promises.writeFile(filename, buffer);
console.log("写入成功");
}
test();
别忘了根据需求选择是否追加写入。
实现复制文件。(fs.copyFile(src, dest[, mode], callback)
)
const fs = require("fs");
const path = require("path");
async function test(){
const fromfilename = path.resolve(__dirname,"./11.jpg");
const buffer = await fs.promises.readFile(fromfilename);
const tofromfilename = path.resolve(__dirname,"./22.jpg");
await fs.promises.writeFile(tofromfilename,buffer);
}
test();
3.fs.stat
提供了关于文件的信息。
const fs = require('fs');
const path = require('path');
const filename = path.resolve(__dirname,"./22.jpg");
async function test(){
const stat = await fs.promises.stat(filename);
console.log(stat);
console.log(new Date(stat.birthtime).toLocaleDateString());
}
test();
检查当前路径是文件还是目录。
async function test(){
const stat = await fs.promises.stat(filename);
console.log("是否是目录", stat.isDirectory());
console.log("是否是文件", stat.isFile());
}
test();
4.fs.readdir
读取目录的内容
const fs = require('fs');
const path = require('path');
const filename = path.resolve(__dirname,"./");
async function test(){
const pathes = await fs.promises.readdir(filename);
console.log(pathes);
}
test();
5.fs.mkdir
异步地创建目录。
const fs = require('fs');
const path = require('path');
const filename = path.resolve(__dirname,"./mkdir");
async function test(){
const pathes = await fs.promises.mkdir(filename);
console.log('创建成功');
}
test();
6.fs.exists
通过检查文件系统来测试给定的路径是否存在。
由于该方法已经被弃用,这里手写实现。
const fs = require("fs");
const path = require("path");
const dirname = path.resolve(__dirname, "./newfile");
async function exists(filename) {
try {
await fs.promises.stat(filename);
return true;
} catch (err) {
if (err.code === "ENOENT") {
//文件不存在
return false;
}
throw err;
}
}
async function test() {
const result = await exists(dirname);
if (result) {
console.log("目录已存在,无需操作");
} else {
await fs.promises.mkdir(dirname);
console.log("目录创建成功");
}
}
test();
7.fs.unlink
异步地删除文件或符号链接。
fs.unlink('文件.txt', (err) => {
if (err) throw err;
console.log('文件已被删除');
});