node--fs
1、fs模块内置方法
1)stat
检测是文件还是目录
fs.stat(fileAddress,(err,stats)=>{
//err 出错信息
//stats.isFile() 该东西是文件吗
//stats.isDirectory() 该东西是目录吗
//返回布尔值
})
2)mkdir
创建目录
fs.mkdir(directoryName,mode,callback)
//directoryName:所创建目录的名称
//mode:目录读写权限,默认0777
//callback:回调,含参数error
fs.mkdir('css',(err)=>{...})
不可建立同名目录
3)writeFile
写入文件
fs.writeFile(...)
参数列表:
不存在自动创建,同名自动覆盖
4)appendFile
追加文件内容
参数同3)相同
若不存在直接创建,若已存在直接在相应文件内容中追加
5)readFile
读取文件
参数列表 3)中除了data外
fs.readFile(path,callback(err,data))
返回Buffer格式,通过toString方法来转换为字符串
6)readdir
读取目录
参数列表 3)中除了data外
fs.readdir(path,callback(err,data))
读取文件下的所有目录和文件
7)rename
重命名或剪切文件
fs.rename(path,samePathWithNewName,callback(err))
剪切文件并放到指定目录:
fs.rename(path,differentPath,callback(err))
8)
删除目录
fs.rmdir()
fs.rmdir(path,cb(err))
不可以删文件
9)unlink
删除文件
fs.unlink(path,cb(err))
//注意:文件的读取等是异步操作
10)createReadStream
以文件流的方式读取数据
这种方式是分块读取的
// node通过文件流的方式读取数据 const fs = require('fs') let str = '' // 用于保存数据 //创建读取对象,参数是文件路径
const readStream = fs.createReadStream('a.txt') //每完成一块数据的读取,广播一个data事件,readStream通过on接收
//文件过大时读取多次
readStream.on('data', (chunk) => {
str += chunk
}) //读取完毕。广播一个end事件,通过on接收
readStream.on('end', () => {
console.log(str)
}) //读取失败。广播一个error事件,通过on接收
readStream.on('error', (err) => {
console.log(err)
})
//通过流的方式读取不会卡死
11)通过createWriteStream
通过文件流的方式写入数据,
不追加直接覆盖
// 通过文件流的方式写入数据 const fs = require('fs')
const data = '这是一段数据2' const writeStream = fs.createWriteStream('b.txt') writeStream.write(data, 'utf8') // 标记写入完成,这样才能触发广播finish事件
writeStream.end() writeStream.on('finish', () => {
console.log('finished')
}) writeStream.on('error', (err) => {
console.log('error occur!' + err)
})
2、管道流
上面的读取流和写入流可以通过pipe方法像倒水一样进行复制转移
node--fs的更多相关文章
- 解决node fs.writeFile 生成csv 文件乱码问题
解决node fs.writeFile 生成csv 文件乱码问题: fs.writeFile('xxx.csv', '\ufeff' + 要传入的数据, {encoding: 'utf8'}); \u ...
- Node+fs+定时器(node-schedule)+MySql
目标:将本人写博客时候的截图保存到桌面的图片 执行保存到指定文件进行整理 并写入数据库 先看最终的目录结构: package.json文件: { "name": "zqz ...
- Node fs, url, http 组合小型的服务器 ( 满足html请求, get, post 传值 )
<script type="text/javascript"> /* * 引入模块 */ var http = require('http'); var url = r ...
- node fs模块
Node.js的文件系统的Api //公共引用 var fs = require('fs'), path = require('path'); 1.读取文件readFile函数 //readFile( ...
- node fs相对路径
如果在js里面使用了node.js的fs,在传入path参数时,如果使用相对路径,按照根目录的层级就是用就好. 比如:目录结构为: a -b -c -c1.js d 在c1.js中调用时,如果需要使用 ...
- Node fs模块异步读取验证并异步写入
console.log("1:开始读成取文件内容...");fs.readFile('./public/2.log',function(err,data){ if(err){ co ...
- Node fs模块同步读取写入追加
JS文件中const fs = require("fs");console.log("开始进入文件读取.."); //同步的写入var data = fs.re ...
- node fs 解决回调地域问题
promisify问题 promisify = require('util).promisify const read = promisify( fs.readFile); read('input.t ...
- Node FS 读取文件中文乱码解决
1:首先保证源文件编码方式为UTF-8 2:读取代码,设置编码方式rs.setEncoding('utf8') var fs = require('fs'); var rs = fs.createRe ...
- node fs 文件/目录 删除
删除文件如下: 过程:先判断文件路径是否存在.读取该文件下所有文件.循环该文件,判断是否是文件夹还是文件. 移除文件夹使用fs.rmdirSync("路径") 移除文件使用fs.u ...
随机推荐
- 新年在家学java之基础篇--循环&数组
因为“野味肺炎”的肆虐,过年被迫宅家只能吃了睡.睡了吃.这么下次只能长膘脑子空空,不如趁此机会重新学习java基础,为日后做铺垫~ 循环结构: 几种循环:for(::),while(){},do{}w ...
- Ubuntu 设置静态 IP
一.背景 如果没有设置静态IP,由于某些情况,会导致系统的 IP 地址发生变化. 为了避免 IP 发生变化,就需要进行静态 IP 的设置. 注:这里 Ubuntu 版本为 19.10 二.解决方案 1 ...
- SpringMVC配置讲解(一)
SpringMVC 核心类和接口 DispatcherServlet -- 前置控制器 在DispatcherServlet的初始化过程中,框架会在web应用的 WEB-INF文件夹下寻找名为[s ...
- JavaScript关键字之super()
https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Operators/super The super keyword ...
- 场景实践篇一:Nginx负载均衡配置
code1 code2 code3 三个文件夹, 每个文件夹下面一个 index.html 的文件夹 cd /etc/nginx/conf.d/ 下面新建 server1.conf ...
- 邪恶的csrf
关于csrf是啥我就不多说了 进入正文 场景模拟 场景一 在一个bbs社区里,用户在发言的时候会发出一个这样的GET请求: #!html GET /talk.php?msg=hello HTTP/1. ...
- django-crontab使用
用 django-crontab 为 Django 添加定时任务 需求 做后台开发的时候,有时候会遇到这样的需求,在某个固定时间或者一定时间间隔自动触发某一事件.比如说我有一个需求要求是,周一到周五早 ...
- 数位dp——BZOJ1026 Windy数
1026: [SCOI2009]windy数 Time Limit: 1 Sec Memory Limit: 162 MB Description windy定义了一种windy数.不含前导零且相邻 ...
- 羽翼sqlmap视频笔记
access 注入 ./sqlmap.py -u "url" 注入判断./sqlmap.py -u "url" --tables 跑表./s ...
- mysql 子查询 合并查询
4.1带In 关键字的子查询 一个查询语句的条件可能落在另一个SELECT 语句的查询结果中. SELECT * FROM t_book WHERE booktypeId IN (SELECT id ...