在进行这些操作之前,需要在js文件中导入fs模块

const fs = require("fs");
  • const是定义一个常量,比较特殊的是,使用const定义时必须赋值,一旦被赋值就不能再修改。

一、操作文件夹

  • 创建文件夹

    • fs.mkdir("test", function(err) {
      if (err) throw err;
      console.log("创建成功");
      })
  • 删除文件夹
    • fs.rmdir("test", err => {
      if (err) throw err;
      console.log("删除成功");
      })
  • 判断文件夹是否存在
    • exists方法现在已经不推荐使用了。
    • fs.exists("test", (exists)=> {
      if (exists) {
      console.log("存在");
      } else {
      console.log("不存在");
      }
      })
    • access方法在有的nodejs版本中需要写成  fs.constants.F_OK
    • fs.access('test', fs.constants.F_OK, (err) => {
      if(err) {
      console.log("文件夹不存在");
      return;
      }
      console.log("文件夹存在");
      })

二、操作文件

  • 写入文件

    • fs.writeFile("123.txt",  "hello word", err => {
      if(err) throw err;
      })
  • 追加文字
    • fs.appendFile("123.txt", "啦啦", err => {
      if(err) throw err;
      })
  • 修改文件名
    • fs.rename("C:/Users/Scr/Desktop/丽丽.bmp", "C:/Users/Scr/Desktop/lili.bmp", err => {
      if(err) throw err;
      console.log("ok");
      })
  • 删除文件
    • fs.unlink("123.txt", err => {
      if(err) throw err;
      console.log("删除完成");
      })
  • 获取文件相关属性
    • fs.stat("C:/Users/Scr/Desktop/lili.bmp", (err, stats) => {
      console.log(stats);
      })
  •  监视文件
    • fs.watchFile("123.txt", (curr, prev) => {
       
      console.log(curr.mtime);
      console.log(prev.mtime);
      })

      监视文件一般会有延迟,可以添加第二个参数,将延迟的时间缩短

    • fs.watchFile('123.txt', {persistent: true, interval: 10}, (curr, prev) => {
        //这里是使用的是模板拼接
      console.log(`the current mtime is: ${curr.mtime}`);
      console.log(`the previous mtime was: ${prev.mtime}`);
      });

三、文件流操作

一般拷贝文件的方法,适合拷贝小文件

"use strict";
const fs = require("fs");
//监视的文件
let currFile = "F:/BleRay.720P.rmvb";
//目标文件
let targetFile = "F:/movie";
//读文件的流
let rs = fs.createReadStream(currFile);
//写文件的流
let ws = fs.createWriteStream(targetFile);
//已经读取的文件大小
let currentCount = 0;
//文件的总大小
let fileSize = fs.statSync(currFile).size;
rs.on("data", (chunk) => {
currentCount += chunk.length;
//每一次获取到的数据---buffer
//console.log(chunk);
ws.write(chunk);
console.log("进度:" + currentCount/fileSize + "%");
})

文件流的方式拷贝

"use strict";
//监视的文件
let currFile = "F:/BleRay.720P.rmvb";
//目标文件
let targetFile = "F:/movie";
const fs = require("fs");
//读文件的流
let rs = fs.createReadStream(currFile);
//写文件的流
let ws = fs.createWriteStream(targetFile); //适合复制大文件,不能显示文件进度
rs.pipe(ws);

File System的简单操作的更多相关文章

  1. 【转】Android adb shell操作时出现“ XXX ... Read-only file system”解决办法--不错

    原文网址:http://blog.csdn.net/whu_zhangmin/article/details/25364349 手机连接PC后 adb shell su rm -r /system/a ...

  2. Android 操作文件系统失败: Read-only file system

    现象: $ adb push /d/Aaron/Desktop/libreference-ril-LS.so system/lib failed to copy 'D:/Aaron/Desktop/l ...

  3. 磁盘、分区及Linux文件系统 [Disk, Partition, Linux File System]

    1.磁盘基础知识 1.1 物理结构 硬盘的物理结构一般由磁头与碟片.电动机.主控芯片与排线等部件组成:当主电动机带动碟片旋转时,副电动机带动一组(磁头)到相对应的碟片上并确定读取正面还是反面的碟面,磁 ...

  4. Linux File System

    目录 . Linux文件系统简介 . 通用文件模型 . VFS相关数据结构 . 处理VFS对象 . 标准函数 1. Linux文件系统简介 Linux系统由数以万计的文件组成,其数据存储在硬盘或者其他 ...

  5. KASS分布式文件系统(Kass File System)

    KASS分布式文件系统(Kass File System),简称KFS,是开始公司自主研发的分布式文件存储服务平台.KFS系统架构及功能服务类似Hadoop/GFS/DFS,它通过HTTP-WEB为上 ...

  6. HTML5之本地文件系统API - File System API

    HTML5之本地文件系统API - File System API 新的HTML5标准给我们带来了大量的新特性和惊喜,例如,画图的画布Canvas,多媒体的audio和video等等.除了上面我们提到 ...

  7. Csharp 简单操作Word模板文件

    原文:Csharp 简单操作Word模板文件 1.创建一个模板的Word文档  Doc1.dot 内容为: To: <Name> Sub:<Subject> Website i ...

  8. 谷歌三大核心技术(一)The Google File System中文版

    谷歌三大核心技术(一)The Google File System中文版  The Google File System中文版 译者:alex 摘要 我们设计并实现了Google GFS文件系统,一个 ...

  9. Ceph: A Scalable, High-Performance Distributed File System译文

    原文地址:陈晓csdn博客 http://blog.csdn.net/juvxiao/article/details/39495037 论文概况 论文名称:Ceph: A Scalable, High ...

随机推荐

  1. jQuery文件上传插件Uploadify(转)

    一款基于flash的文件上传,有进度条和支持大文件上传,且可以多文件上传队列. 这款在flash的基础上增加了html5的支持,所以在移动端也可以使用. 由于官方提供的版本是flash免费,html5 ...

  2. HDU 1233 还是畅通工程(最小生成树)

    传送门 还是畅通工程 Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total ...

  3. NOIp2016 Day1&Day2 解题报告

    Day1 T1 toy 本题考查你会不会编程. //toy //by Cydiater //2016.11.19 #include <iostream> #include <cstd ...

  4. 继承 原生js 与 $.extend(true,default,opts||{});

    $.extend(true,default,opts||{}); var obj1={ name:'liu', sex:'m', work:'pc' } var obj2={ sex:'w' } va ...

  5. .net Socket 通信简单实例(初级入门)

    c/s控制台应用程序,Server.Client分别在两个项目中 服务端 using System; using System.Collections.Generic; using System.Li ...

  6. JavaScript中的私有属性

    一.使用构造函数获得私有属性: function Gadget(){ var name = 'iPod'; this.getName = function(){ return name; }; }; ...

  7. href,src,url 整理

    一.href 和 src 的定义及区别 href:Hypertext Reference(超文本引用),指定网络资源的位置,从而在当前元素或者当前文档和由当前属性定义的需要的锚点或资源之间定义一个链接 ...

  8. 数学规划模型的matlab求解 非线性最小二乘lsqnonlin

    LINK :http://blog.sina.com.cn/s/blog_49f037d60100ok8y.html

  9. 1. web前端开发分享-css,js入门篇

    关注前端这么多年,没有大的成就,就入门期间积累了不少技巧与心得,跟大家分享一下,不一定都适合每个人,毕竟人与人的教育背景与成长环境心理活动都有差别,但就别人的心得再结合自己的特点,然后探索适合自己的学 ...

  10. JSP内置对象之request对象【学习笔记】

    request对象是JSP中重要的对象,每个request对象封装着一次用户的请求,并且所有的请求参数都被封装在request对象中,因此request对象是获取请求参数的重要途径. 一.获取请求头与 ...