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 ...
随机推荐
- Qt HWND的句柄与QWidget的转换
QT中用到HWND的句柄在编程中遇到了问题,第三方API用了hwnd类型做形参,但是QT中又没有该类型,可以做如下操作来解决问题. 在.h中先声明: HWND m_hWnd; 再声明 public: ...
- 用windows下的Anaconda搭建Django虚拟环境
Django 是一个Python定制框架,可用于简便.快速的开发数据库驱动的web站点. 要使用Django,首先要建立一个虚拟工作环境. 那么,为什么要搭建虚拟环境呢?我们来看以下的开发场景: 假设 ...
- samtools faidx
$ samtools faidx t1.fa && echo "faidx built" $ cat t1.fa.fai scaffold332 scaffold3 ...
- 1)public,provite和protect不能放在函数函数头
今天我才知道,原来这三个修饰的东西,只是用在类里面方法,怪不得一个叫方法,一个叫函数了,原来就是区分他们,哎, 今天遇到这么一个问题: <?php //header('Content-type: ...
- Spring Security Config : 注解 EnableWebSecurity 启用Web安全
https://blog.csdn.net/andy_zhang2007/article/details/90023901
- Codeforces Round #200 (Div. 1)D. Water Tree
简单的树链剖分+线段树 #include<bits\stdc++.h> using namespace std; #define pb push_back #define lson roo ...
- ambulance|severely|halt
N-COUNT 救护车An ambulance is a vehicle for taking people to and from hospital. very seriously 严重地 Thei ...
- OLED带来全新视觉体验
2013年1月,在国际消费电子展(CES)上世界首款曲面OLED电视--LG OLED电视亮相,LG Display将曲面与OLED完美结合的面板技术让显示设备的外观和品质都达到了一个全新的高度,惊艳 ...
- Linux启动初始化配置文件浅析
转自:http://blog.51cto.com/19055/1144600 1)/etc/profile 登录时,会执行. 全局(公有)配置,不管是哪个用户,登录时都会读取该文件. (2)/ec ...
- <JZOJ5944>信标
emmm树形dp?好像是的 搬一个题解证明过来 由于在n>1时答案至少为1,我们枚举一个必须放的根, 所有深度不同的点就被区分开了. 设一个节点有c个儿子, 发现必须在其中至少c−1个儿子的子树 ...