JavaScript实现批量重命名文件

 更新时间:2024年12月12日 10:42:02   作者:Face  
这篇文章主要为大家详细介绍了如何利用JavaScript实现批量重命名文件,文中的示例代码讲解详细,有需要的小伙伴可以跟随小编一起学习一下

批量重命名图片

改下载的图片中的名称时候,感觉一个个修改太麻烦了,就像写个脚本执行一下,顺便多熟悉一下node的fs模块

一次性对某一文件夹下多个图片文件进行名称的修改与调整,不用逐一手动重命名图片,快速更新文件名,执行脚本自动修改图片名

自动“9a9f0a7f89a7.jpg”,之类的图片名为002.jpg

我这里将设置文件重命名为从0 ~ 999,可以根据要命名的图片数量自定义设置。

reName.js代码如下:

const fs = require("fs");
const path = require("path");
// 要修改的文件路径
const folderPath = "./testPicture";
const imgType = ["jpg", "png", "jpeg", "gif", "bmp", "tiff", "ico", "webp"];

let count = 0;
function pad(num, size) {
	let s = num + "";
	while (s.length < size) s = "0" + s;
	return s;
}

fs.readdir(folderPath, (err, files) => {
	try {
		if (err) {
			console.error("读取文件出错", err);
			return;
		}
		files.forEach((file) => {
			// 如果用 path.extname() 获取扩展名,注意名称为空的额外处理
			const ext = file.split(".").at(-1).toLowerCase();		
			if (imgType.includes(ext)) {
				const oldFilePath = path.join(folderPath, file);
				const newFileName = pad(count, 3) + "." + ext;
				const newFilePath = path.join(folderPath, newFileName);
				fs.rename(oldFilePath, newFilePath, (err) => {		
					if (err) console.error("重命名文件出错", err);
				});
				count++;
			}
		});
		console.log(`重命名完成,共重命名 ${count} 个文件`);
	} catch (error) {
		throw new Error(error);
	}
});

如果要修改重命名其他文件,修改imgType中的文件类型执行脚本即可

  • 执行脚本直接使用 node 运行即可node reName.js
  • 运行之前先备份!!!

方法补充

除了上文的方法,小编还为大家整理了一些其他JavaScript重命名文件的方法,有需要的可以了解下

方法一:

'use strict'

let fs = require('fs');
let args = process.argv;
let dist = 'dist';
let src = 'src';
let index = 0;
let ignore = '';

// 目标路径
dist = args[2];
// 名字前缀
src = args[3];
// 递增后缀
index = args[4] || 1;
// ? 忽略的文件
ignore = args[5] || "";

let files = fs.readdirSync(dist);
let sortValue = ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9'];
files.sort(function (a, b) {
    let index = -1;
    for (let i = sortValue.length - 1; i >= 0; i--) {
        index = a.indexOf(sortValue[i]);
        if (index != -1) {
            // console.log("a: ", a, " i: ", i, " index: ", index);
            break;
        }
    }

    if (index == -1) {
        return 0;
    }
    else {
        let aid = parseInt(a.substring(index));
        let bid = parseInt(b.substring(index));
        if (aid == NaN || bid == NaN) {
            return 0;
        }
        else {
            return aid - bid;
        }
    }
});

for (let i = 0; i < files.length; i++) {
    if (ignore !== "" && files[i].indexOf(ignore) === -1) {
        continue;
    }
    let stat = fs.statSync(dist + "\\" + files[i]);
    let runRename = function (stat) {
        if (stat.isFile()) {
            let prefix = dist + "\\";
            let suffix = files[i].substring(files[i].indexOf("."));
            let oldName = prefix + files[i];
            let newName = prefix + src + index + suffix;
            fs.renameSync(oldName, newName);
            index++;
        }
    };
    runRename(stat);
}

方法二:js 批量修改文件名后缀

在需要修改的文件夹除创建一个js文件 ,通过 node .\****.js 运行或在创建一个.bat文件:node .****.js pause 后双击

记得修改dirName

// 引入 fs 文件系统模块
let fs = require('fs')

const dirName = 'mus' // 读取目标文件夹名称
const reg = /(?<=[.])[a-z]+/ // 文件后缀 匹配规则

// 读文件夹,获取文件名列表
let fileList = fs.readdirSync(dirName)

// 过滤出想要的文件类型
let resultList = fileList.reduce((pev, cur) => {
  // 获取后缀
  const curPicType = cur.match(reg)[0]
  if (['mgg', 'flac', 'ogg', 'lrc'].includes(curPicType)) {
    pev.push(cur)
  }
  return pev
}, [])
console.log('文件列表', resultList)

// 循环当前文件名列表,根据需要重写名字
for (let i = 0; i < resultList.length; i++) {
  // 文件完整名称
  const curFileName = resultList[i]
  // 后缀名
  const fileFormat = curFileName.match(reg)[0]
  // 去掉后缀的文件名
  const fileCode = curFileName.split('.')[0]


  // oldPath 原地址
  const oldPath = `./${dirName}/${curFileName}`
  // newPath 目标地址
  let newPath = ''

  // 修改方式
  // 如果想根据不同条件,将文件分别放到不同的文件夹,按需更改 newPath 即可
  if (fileFormat == 'ogg' || fileFormat == 'mgg') {
    newPath = `./${dirName}/${fileCode}.mp3`
  } else {
    newPath = oldPath
  }

  // 确认修改
  fs.rename(oldPath, newPath, (err) => {
    if (err) throw err;
    console.log(`修改成功 -- ${newPath}`);
  })
}

到此这篇关于JavaScript实现批量重命名文件的文章就介绍到这了,更多相关JavaScript重命名文件内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Bootstrap 折叠(Collapse)插件用法实例详解

    Bootstrap 折叠(Collapse)插件用法实例详解

    这篇文章主要介绍了Bootstrap 折叠(Collapse)插件用法实例详解的相关资料,需要的朋友可以参考下
    2016-06-06
  • Bootstrap Table使用整理(五)之分页组合查询

    Bootstrap Table使用整理(五)之分页组合查询

    这篇文章主要介绍了 Bootstrap Table使用整理(五)之分页组合查询的实例代码,非常报错,具有参考借鉴价值,需要的朋友可以参考下
    2017-06-06
  • AJAX跨域请求json数据的实现方法

    AJAX跨域请求json数据的实现方法

    这篇文章介绍了AJAX跨域请求json数据的实现方法,有需要的朋友可以参考一下
    2013-11-11
  • JS得到当前时间的方法示例

    JS得到当前时间的方法示例

    这篇文章主要介绍了JS得到当前时间的方法,结合具体实例形式对比分析了javascript获取日期时间的相关操作技巧,需要的朋友可以参考下
    2017-03-03
  • JavaScript常见继承模式实例小结

    JavaScript常见继承模式实例小结

    这篇文章主要介绍了JavaScript常见继承模式,结合实例形式总结分析了javascript原型链继承、构造函数继承、组合继承、原型式继承、寄生式继承等相关实现技巧与操作注意事项,需要的朋友可以参考下
    2019-01-01
  • 原生js实现表格翻页和跳转

    原生js实现表格翻页和跳转

    这篇文章主要为大家详细介绍了原生js实现表格翻页和跳转,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-09-09
  • Bootstrap简单实用的表单验证插件BootstrapValidator用法实例详解

    Bootstrap简单实用的表单验证插件BootstrapValidator用法实例详解

    这篇文章主要介绍了Bootstrap简单实用的表单验证插件BootstrapValidator用法,结合实例形式详细分析了Bootstrap表单验证插件BootstrapValidator基本功能、原理、用法及操作注意事项,需要的朋友可以参考下
    2020-03-03
  • Javascript 事件流和事件绑定

    Javascript 事件流和事件绑定

    本文中的部分观点参考至《Javascript高级程序设计》(很好的一本书,推荐大家看看!),addEvent函数借鉴了YUI2.7的_addListener方法,这里也要谢谢YUI那些牛人,向他们致敬!
    2009-07-07
  • LayUI switch 开关监听 获取属性值、更改状态的方法

    LayUI switch 开关监听 获取属性值、更改状态的方法

    今天小编就为大家分享一篇LayUI switch 开关监听 获取属性值、更改状态的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-09-09
  • Vue.js实现页面后退时还原滚动位置的操作方法

    Vue.js实现页面后退时还原滚动位置的操作方法

    Vuet看起来也不是很复杂,只需要定义好模块状态,然后在组件中设置对应的规则来更新模块的状态即可,这篇文章主要介绍了Vue.js实现页面后退时还原滚动位置的实现方法,需要的朋友可以参考下
    2022-07-07

最新评论