Node.js-fs模块文件创建、删除、重命名、文件内容的写入、读取以及文件夹的相关操作
一、写入文件操作
异步写入:writeFile()
同步写入:writeFileSync()
const fs = require("fs");
fs.writeFile("目标文件路径", "要写入的内容", err => {if(err){console.log(err);return;}console.log("写入成功!");
})
二、文件追加写入操作
异步追加写入:appendFile()
同步追加写入:appendFileSync()
方式一(appendFile):
const fs = require("fs");
fs.appendFile("目标文件路径", "要追加写入的内容", err => {if(err){console.log(err);return;}console.log("追加写入成功!");
})
方式二(writeFile):
const fs = require("fs");
fs.writeFile("目标文件路径", "要追加写入的内容", { flag: "a" }, err => {if(err){console.log(err);return;}console.log("追加写入成功!");
})
三、文件流式写入操作
fs.createWriteStream( path [, options ] )
- 程序打开一个文件是需要消耗资源的 ,流式写入可以减少打开关闭文件的次数。
- 流式写入方式适用于大文件写入或者频繁写入的场,writeFile 适合于写入频率较低的场景。
// 导入 fs 模块
const fs = require("fs");
// 创建写入流对象
const ws = fs.createWriteStream("目标文件路径");
// write 写入
ws.write("我喜欢你脸红红的样子,");
ws.write("更喜欢你气喘吁吁的样子。");
// 关闭写入流通道
ws.close();
四、文件读取操作
异步读取:readFile()
同步读取:readFileSync()
- 通过程序从文件中取出其中的数据
const fs = require("fs");
fs.readFile("目标文件路径", (err, data) => {if(err){console.log(err)return;}// 读取成功后的内容console.log(data.toString())
})
应用场景: 电脑开机、程序运行、编根器打开文件、查看图片、放视频、放音乐、Git查看日志、上传文件、查找聊天记录等。
五、文件流式读取操作
const fs = requrie("fs");
// 创建读取流对象
const rs = fs.createReadStream("目标文件路径");
// 绑定 data 事件,chunk 表示文件块儿
rs.on("data", chunk => {console.log(chunk);
})
// end 可选事件
rs.on("end", () => {console.log("文件读取成功!");
})
六、文件复制操作
- 方式一
// 先读取文件,再把读取到的内容写入到另一个文件中。
const fs = require("fs");
const data = fs.readFileSync("源文件路径");
fs.writeFileSync("目标文件路径", data);
- 方式二(推荐)
// 通过流式操作,占用内存空间少
const fs = requrie("fs");
const rs = fs.createReadStream("源文件路径");
const ws = fs.createWriteStream("目标文件路径");
// 绑定 data 事件
fs.on("data", chunk => {ws.write(chunk);
})
七、文件重命名和移动操作
异步操作:rename(oldPath, newPath, callback)
同步操作:renameSync(oldPath, newPath)
// 通过 rename 完成文件重命名
const fs = require("fs");
fs.rename("./index.html", "./main.html", err => {if(err){console.log(err);return;}console.log("文件重命名成功!");
})
// 通过 rename 完成文件移动
const fs = require("fs");
fs.rename("./index/index.html", "./main/index.html", err => {if(err){console.log(err);return;}console.log("文件移动成功!");
})
八、文件删除操作
异步删除:unlink(path, callback)
同步删除:unlinkSync(path)
- 方式一
const fs = requrie("fs");
fs.unlink("要删除的文件路径", err => {if(err){console.log(err);return;}console.log("文件删除成功!");
})
异步删除:rm(path, callback)
同步删除:rmSync(path)
- 方式二
const fs = requrie("fs");
fs.rm("要删除的文件路径", err => {if(err){console.log(err);return;}console.log("文件删除成功!");
})
九、文件夹操作
创建文件夹:mkdir()
const fs = require("fs");
fs.mkdir("要创建的文件夹", err => {if(err){console.log(err);return;}console.log("文件夹创建成功!");
})
递归创建文件夹(多级文件夹目录):
const fs = require("fs");
fs.mkdir("./a/b/c", { recursive: true }, err => {if(err){console.log(err);return;}console.log("文件夹创建成功!");
})
读取文件夹:readdir()
const fs = require("fs");
fs.readdir("./index", (err, data) => {if(err){console.log(err);return;}// 获取目标文件夹当中资源名称列表console.log(data);
})
删除文件夹:rmdir()
const fs = require("fs");
fs.rmdir("./index", err => {if(err){console.log(err);return;}console.log("删除成功!");
})
递归删除文件夹(多级文件夹目录):
const fs = require("fs");
fs.rm("./index", { recursive: true }, err => {if(err){console.log(err);return;}console.log("删除成功!");
})
十、查看资源信息
const fs = require("fs");
// stat status缩写 状态
fs.stat("./index/index.html", (err, data) => {if(err){console.log(err);return;}console.log(data); // 获取文件资源信息console.log(data.isFile()); // true 是否为文件console.log(data.isDirectory()); // false 是否为文件夹
})
相关文章:
Node.js-fs模块文件创建、删除、重命名、文件内容的写入、读取以及文件夹的相关操作
一、写入文件操作 异步写入:writeFile() 同步写入:writeFileSync() const fs require("fs"); fs.writeFile("目标文件路径", "要写入的内容", err > {if(err){console.log(err);return;}console.log("写入成功&a…...
LIN协议总结
目录 一、LIN是什么1、LIN的概念2、扩展介绍一下同步通信和异步通信的区别3、LIN连接结构及节点构成 二、LIN的特点三、LIN协议层1、帧的结构2、帧的类型3、进度表4、状态机实现5、网络管理6、状态管理 四、帧收发的硬件实现1、组成2、硬件特点3、协议控制器4、总线收发器5、LI…...
Redis BigKey案例
面试题: 阿里广告平台,海量数据里查询某一固定前缀的key小红书,你如何生产上限制keys*/flushdb/flushall等危险命令以防止误删误用?美团,MEMORY USAGE命令你用过吗?BigKey问题,多大算big&#…...
ThinkPHP v6.0.8 CacheStore 反序列化漏洞
漏洞说明 1. 漏洞原理:ThinkPHP 6.0.8 CacheStore 会触发POP利用链子,造成任意命令执行 2. 组件描述: ThinkPHP是一个免费开源的,快速、简单的面向对象的轻量级PHP开发框架 3. 影响版本:V6.0.8 漏洞复现 1. 环境安…...
Spring 事务详解(注解方式)
目 录 序言 1、编程式事务 2、配置声明式事务 2.1 基于TransactionProxyFactoryBean的方式(不常用,因为要为每一个类配置TransactionProxyFactoryBean) 2.2 基于AspectJ的XML方式(常用,可配置在某些类下的所有子…...
华为云waf 使用场景
防护Web应用免受攻击就用华为云Web应用防火墙 Web应用防火墙(Web Application Firewall, WAF),通过对HTTP(S)请求进行检测,识别并阻断SQL注入、跨站脚本攻击、网页木马上传、命令/代码注入、文件包含、敏感文件访问、第…...
?.的写法 后缀修饰符
概览:处理后端返回的数据data,写法:data?.name。解决vue框架编译出现的报错Cannot read property name of undefined。出现问题的原因:这是因为我们试图访问对象中不在的 key 为 name 的属性,那么怎么解决呢ÿ…...
org.apache.hadoop.hive.ql.exec.DDLTask. show Locks LockManager not specified解决
Error while processing statement: FAILED: Execution Error, return code 1 from org.apache.hadoop.hive.ql.exec.DDLTask. show Locks LockManager not specified解决 当在Hive中执行show locks语句时,出现"LockManager not specified"错误通常是由于…...
Adaptive autosar 都有哪些模块?各有什么功能?
Adaptive autosar是一种用于高性能计算ECU的软件平台,它支持自适应应用程序的开发和运行。它由两部分组成:基础(Foundation)和服务(Service)。基础包括了操作系统接口、执行管理、网络管理、识别访问管理、加密、更新和配置管理等功能。服务包括了通信管理、RESTful、时间…...
C++ 动态内存分配
在C中动态内存的分配技术可以保证程序在允许过程中按照实际需要申请适量的内存,使用结束后还可以释放,这种在程序运行过程中申请和释放的存储单元也称为堆。 申请和释放过程一般称为建立和删除。 在C程序中,建立和删除堆对象使用两个运算符&…...
设计模式——面向对象的7大设计原则
1.单一职责原则 一个类中最好只放一种类型的方法,比如Dao中只有和数据库交互相关的代码。实现高内聚,低耦合。 2.开闭原则 对外拓展开放,对内修改关闭,有新的需求时不要修改已有代码,而是添加新的代码,比…...
智慧防汛,数字科技的力量
随着夏日的脚步临近,台风季节即将降临。对于那些居住在沿海地区的人们来说,台风是一种常见的自然灾害,其带来的风雨可能对生命和财产造成严重威胁。然而,随着数字科技的飞速发展,可视化技术为防汛抗台工作带来了全新的…...
“中国软件杯”飞桨赛道晋级决赛现场名单公布
“中国软件杯”大学生软件设计大赛是由国家工业和信息化部、教育部、江苏省人民政府共同主办,是全国软件行业规格最高、最具影响力的国家级一类赛事,为《全国普通高校竞赛排行榜》榜单内赛事。今年,组委会联合百度飞桨共同设立了“智能系统设…...
JDBC处理批量数据提高效率
文章目录 0 说明1 如何使用jdbc操作数据库1.1 加载数据库驱动1.2 建立数据库连接1.3 创建Statement或者PreparedStatement用来执行SQL1.4 开始执行SQL语句1.5 处理结果集1.6 关闭连接1.7 完整代码 2 批量操作数据库3 如何打印SQL语句4 jdbc常用开源类库 1 JDBC实现往MySQL插入百…...
使用css和js给按钮添加微交互的几种方式
使用css和js给按钮添加微交互的几种方式 在现实世界中,当我们轻弹或按下某些东西时,它们会发出咔嗒声,例如电灯开关。有些东西会亮起或发出蜂鸣声,这些响应都是“微交互”,让我们知道我们何时成功完成了某件事。在本文…...
react面试之context的value变化时,内部所有子组件是否变化
上测试代码 // context const state {a: 1,b: 1, } const context createContext(state);export default context; // A组件 const A () > {const { a } useContext(context);return (<div>{a}</div>) } export default A;// B组件 const B () > {cons…...
使用okHttp不走代理问题
背景 某日使用okhttp设置代理并发送爬虫请求时,发现部分url请求没有走代理直接和目标url建立了连接,伪代码如下。初始化okhttpClient时设置了proxySelecter代理,但是调用okhttpClient.newCall请求时并没用调用proxySelecter.select函数获取代…...
python moviepy 自动化音视频处理实践
MoviePy是一个用于视频编辑的Python库。它提供了一种简单且直观的方式来处理视频文件,包括剪辑、合并、裁剪、添加文本、添加音频等操作。使用MoviePy,你可以通过编写Python代码来创建和编辑视频,而无需使用复杂的视频编辑软件。 MoviePy建立…...
聊聊混合动力汽车和纯电骑车的优势和劣势
混合动力汽车和纯电动骑车是两种不同的交通工具,它们都有各自的优势和劣势。本文将分别探讨混合动力汽车和纯电动骑车的优势和劣势,并为文章提供三个备选的好听的标题。 混合动力汽车是一种结合了内燃机和电动机的汽车,它可以同时利用燃油和电…...
算法训练Day39|62.不同路径 ● 63. 不同路径 II
LeetCode:62.不同路径 62. 不同路径 - 力扣(LeetCode) 1.思路 想象成矩阵填格子,两个关键点,初始化和递推公式。 初始化除点(0,0)第一行第一列均为1,递推公式推导dp[i][j] dp[i …...
盘古信息PCB行业解决方案:以全域场景重构,激活智造新未来
一、破局:PCB行业的时代之问 在数字经济蓬勃发展的浪潮中,PCB(印制电路板)作为 “电子产品之母”,其重要性愈发凸显。随着 5G、人工智能等新兴技术的加速渗透,PCB行业面临着前所未有的挑战与机遇。产品迭代…...
抖音增长新引擎:品融电商,一站式全案代运营领跑者
抖音增长新引擎:品融电商,一站式全案代运营领跑者 在抖音这个日活超7亿的流量汪洋中,品牌如何破浪前行?自建团队成本高、效果难控;碎片化运营又难成合力——这正是许多企业面临的增长困局。品融电商以「抖音全案代运营…...
macOS多出来了:Google云端硬盘、YouTube、表格、幻灯片、Gmail、Google文档等应用
文章目录 问题现象问题原因解决办法 问题现象 macOS启动台(Launchpad)多出来了:Google云端硬盘、YouTube、表格、幻灯片、Gmail、Google文档等应用。 问题原因 很明显,都是Google家的办公全家桶。这些应用并不是通过独立安装的…...
Qwen3-Embedding-0.6B深度解析:多语言语义检索的轻量级利器
第一章 引言:语义表示的新时代挑战与Qwen3的破局之路 1.1 文本嵌入的核心价值与技术演进 在人工智能领域,文本嵌入技术如同连接自然语言与机器理解的“神经突触”——它将人类语言转化为计算机可计算的语义向量,支撑着搜索引擎、推荐系统、…...
Nuxt.js 中的路由配置详解
Nuxt.js 通过其内置的路由系统简化了应用的路由配置,使得开发者可以轻松地管理页面导航和 URL 结构。路由配置主要涉及页面组件的组织、动态路由的设置以及路由元信息的配置。 自动路由生成 Nuxt.js 会根据 pages 目录下的文件结构自动生成路由配置。每个文件都会对…...
pikachu靶场通关笔记22-1 SQL注入05-1-insert注入(报错法)
目录 一、SQL注入 二、insert注入 三、报错型注入 四、updatexml函数 五、源码审计 六、insert渗透实战 1、渗透准备 2、获取数据库名database 3、获取表名table 4、获取列名column 5、获取字段 本系列为通过《pikachu靶场通关笔记》的SQL注入关卡(共10关࿰…...
Docker 本地安装 mysql 数据库
Docker: Accelerated Container Application Development 下载对应操作系统版本的 docker ;并安装。 基础操作不再赘述。 打开 macOS 终端,开始 docker 安装mysql之旅 第一步 docker search mysql 》〉docker search mysql NAME DE…...
Java数值运算常见陷阱与规避方法
整数除法中的舍入问题 问题现象 当开发者预期进行浮点除法却误用整数除法时,会出现小数部分被截断的情况。典型错误模式如下: void process(int value) {double half = value / 2; // 整数除法导致截断// 使用half变量 }此时...
关于uniapp展示PDF的解决方案
在 UniApp 的 H5 环境中使用 pdf-vue3 组件可以实现完整的 PDF 预览功能。以下是详细实现步骤和注意事项: 一、安装依赖 安装 pdf-vue3 和 PDF.js 核心库: npm install pdf-vue3 pdfjs-dist二、基本使用示例 <template><view class"con…...
ui框架-文件列表展示
ui框架-文件列表展示 介绍 UI框架的文件列表展示组件,可以展示文件夹,支持列表展示和图标展示模式。组件提供了丰富的功能和可配置选项,适用于文件管理、文件上传等场景。 功能特性 支持列表模式和网格模式的切换展示支持文件和文件夹的层…...
