node文件批量重命名的方法示例


Posted in Javascript onOctober 23, 2017

在一个实际需求中,需要对一批文件(如:文本、图片)进行重命名,按照数字编号。正好借此熟悉了一下node的fs文件操作,写了一个批量修改文件名的脚本。

需求

现有以下图片文件

node文件批量重命名的方法示例

需要批量修改文件名称,变为统一前缀名称并且自增索引,修改后效果

node文件批量重命名的方法示例

最简单的人力操作就是逐个文件重命名,但本着DRY(Don't repeat yourself)原则,还是写一个node脚本搞定。

研究

node中要进行文件操作需要了解一下fs模块

在fs模块中有同步和异步两种方式

读取文件

//异步
fs.readFile('test.txt', 'utf-8' (err, data) => {
  if (err) {
    throw err;
  }
  console.log(data);
});

//同步
let data = fs.readFileSync('test.txt');
console.log(data);

异步读取文件参数:文件路径,编码方式,回调函数

写入文件

fs.writeFile('test2.txt', 'this is text', { 'flag': 'w' }, err => {
  if (err) {
    throw err;
  }
  console.log('saved');
});

写入文件参数:目标文件,写入内容,写入形式,回调函数

flag写入方式:

r:读取文件
w:写文件
a:追加

创建目录

fs.mkdir('dir', (err) => {
  if (err) {
    throw err;
  }
  console.log('make dir success');
});

dir为新建目录名称

读取目录

fs.readdir('dir',(err, files) => {
  if (err) {
    throw err;
  }
  console.log(files);
});

dir为读取目录名称,files为目录下的文件或目录名称数组

获取文件信息

fs.stat('test.txt', (err, stats)=> {
  console.log(stats.isFile());     //true
})

获取文件信息后stats方法:

方法 说明
stats.isFile() 是否为文件
stats.isDirectory() 是否为目录
stats.isBlockDevice() 是否为块设备
stats.isCharacterDevice() 是否为字符设备
stats.isSymbolicLink() 是否为软链接
stats.isFIFO() 是否为UNIX FIFO命令管道
stats.isSocket() 是否为Socket

创建读取流

let stream = fs.createReadStream('test.txt');

创建写入流

let stream = fs.createWriteStreamr('test_copy.txt');

开发

开发思路:

  1. 读取源目录
  2. 判读存放目录是否存在,不存在时新建目录
  3. 复制文件
  4. 判断复制内容是否为文件
  5. 创建读取流
  6. 创建写入流
  7. 链接管道,写入文件内容
let fs = require('fs'),
  src = 'src',
  dist = 'dist',
  args = process.argv.slice(2),
  filename = 'image',
  index = 0;

//show help
if (args.length === 0 || args[0].match('--help')) {
  console.log('--help\n \t-src 文件源\n \t-dist 文件目标\n \t-n 文件名\n \t-i 文件名索引\n');
  return false;
}

args.forEach((item, i) => {
  if (item.match('-src')) {
    src = args[i + 1];
  } else if (item.match('-dist')) {
    dist = args[i + 1];
  } else if (item.match('-n')) {
    filename = args[i + 1];
  } else if (item.match('-i')) {
    index = args[i + 1];
  }
});

fs.readdir(src, (err, files) => {
  if (err) {
    console.log(err);
  } else {
    fs.exists(dist, exist => {
      if (exist) {
        copyFile(files, src, dist, filename, index);
      } else {
        fs.mkdir(dist, () => {
          copyFile(files, src, dist, filename, index);
        })
      }
    });
  }
});

function copyFile(files, src, dist, filename, index) {
  files.forEach(n => {
    let readStream,
      writeStream,
      arr = n.split('.'),
      oldPath = src + '/' + n,
      newPath = dist + '/' + filename + index + '.' + arr[arr.length - 1];
    fs.stat(oldPath, (err, stats) => {
      if (err) {
        console.log(err);
      } else if (stats.isFile()) {
        readStream = fs.createReadStream(oldPath);
        writeStream = fs.createWriteStream(newPath);
        readStream.pipe(writeStream);
      }
    });
    index++;
  })
}

效果

node文件批量重命名的方法示例

总结

node提供了很多模块可以帮助我们完成不同需求的功能开发,使javascript不仅仅局限与浏览器中,尝试自己编写一些脚本有助于对这些模块的理解,同时也能提高办公效率。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
newxtree.js代码
Mar 13 Javascript
用javascript将数据库中的TEXT类型数据动态赋值到TEXTAREA中
Apr 20 Javascript
jquery $(document).ready() 与window.onload的区别
Dec 28 Javascript
javascript自启动函数的问题探讨
Oct 05 Javascript
JavaScript的原型继承详解
Feb 15 Javascript
Angular2环境搭建具体操作步骤(推荐)
Aug 04 Javascript
mpvue中配置vuex并持久化到本地Storage图文教程解析
Mar 15 Javascript
VUE引入第三方js包及调用方法讲解
Mar 01 Javascript
vue+web端仿微信网页版聊天室功能
Apr 30 Javascript
详解Vue后台管理系统开发日常总结(组件PageHeader)
Nov 01 Javascript
AudioContext 实现音频可视化(web技术分享)
Feb 24 Javascript
vue3引入highlight.js进行代码高亮的方法实例
Apr 08 Vue.js
详解vue 实例方法和数据
Oct 23 #Javascript
深入浅析javascript继承体系
Oct 23 #Javascript
Vue.js组件通信的几种姿势
Oct 23 #Javascript
Vue2.0+ElementUI实现表格翻页的实例
Oct 23 #Javascript
JavaScript之创意时钟项目(实例讲解)
Oct 23 #Javascript
浅谈js的解析顺序 作用域 严格模式
Oct 23 #Javascript
基于Vue2.0+ElementUI实现表格翻页功能
Oct 23 #Javascript
You might like
超级简单的php+mysql留言本源码
2009/11/11 PHP
php HtmlReplace输入过滤安全函数
2010/07/03 PHP
PHP中strtotime函数使用方法详解
2011/11/27 PHP
PHP图片裁剪与缩放示例(无损裁剪图片)
2017/02/08 PHP
PHP redis实现超迷你全文检索
2017/03/04 PHP
PHP文件后缀不强制为.php方法
2019/03/31 PHP
收集的10个免费的jQuery相册
2011/02/26 Javascript
通过Javascript创建一个选择文件的对话框代码
2012/06/16 Javascript
Dom 学习总结以及实例的使用介绍
2013/04/24 Javascript
Js使用WScript.Shell对象执行.bat文件和cmd命令
2014/12/18 Javascript
jQuery实现的Div窗口震动效果实例
2015/08/07 Javascript
基于JavaScript如何实现私有成员的语法特征及私有成员的实现方式
2015/10/28 Javascript
node.js连接mongoDB数据库 快速搭建自己的web服务
2016/04/17 Javascript
Jquery跨域获得Json的简单实例
2016/05/18 Javascript
微信小程序 删除项目工程实现步骤
2016/11/10 Javascript
jQuery+pjax简单示例汇总
2017/04/21 jQuery
微信小程序 支付功能(前端)的实现
2017/05/24 Javascript
jQuery使用$.extend(true,object1, object2);实现深拷贝对象的方法分析
2019/03/06 jQuery
微信小程序API—获取定位的详解
2019/04/30 Javascript
关于vue路由缓存清除在main.js中的设置
2019/11/06 Javascript
如何实现js拖拽效果及原理解析
2020/05/08 Javascript
vue 实现把路由单独分离出来
2020/08/13 Javascript
Python批量更改文件名的实现方法
2017/10/29 Python
python如何派生内置不可变类型并修改实例化行为
2018/03/21 Python
python中协程实现TCP连接的实例分析
2018/10/14 Python
对python中大文件的导入与导出方法详解
2018/12/28 Python
Python3.7 新特性之dataclass装饰器
2019/05/27 Python
打包python 加icon 去掉cmd黑窗口方法
2019/06/24 Python
基于python中__add__函数的用法
2019/11/25 Python
TensorBoard 计算图的查看方式
2020/02/15 Python
解决import tensorflow as tf 出错的原因
2020/04/16 Python
韩国最大的购物网站:Gmarket
2019/06/20 全球购物
公司培训心得体会
2014/01/03 职场文书
董事长岗位职责
2015/02/13 职场文书
详解gantt甘特图可拖拽、编辑(vue、react都可用 highcharts)
2021/11/27 Vue.js
python pandas 解析(读取、写入)CSV 文件的操作方法
2022/12/24 Python