欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript實現(xiàn)批量重命名文件

 更新時間:2024年12月12日 10:42:02   作者:Face  
這篇文章主要為大家詳細介紹了如何利用JavaScript實現(xiàn)批量重命名文件,文中的示例代碼講解詳細,有需要的小伙伴可以跟隨小編一起學習一下

批量重命名圖片

改下載的圖片中的名稱時候,感覺一個個修改太麻煩了,就像寫個腳本執(zhí)行一下,順便多熟悉一下node的fs模塊

一次性對某一文件夾下多個圖片文件進行名稱的修改與調(diào)整,不用逐一手動重命名圖片,快速更新文件名,執(zhí)行腳本自動修改圖片名

自動“9a9f0a7f89a7.jpg”,之類的圖片名為002.jpg

我這里將設(shè)置文件重命名為從0 ~ 999,可以根據(jù)要命名的圖片數(shù)量自定義設(shè)置。

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中的文件類型執(zhí)行腳本即可

  • 執(zhí)行腳本直接使用 node 運行即可node reName.js
  • 運行之前先備份?。。?/strong>

方法補充

除了上文的方法,小編還為大家整理了一些其他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 批量修改文件名后綴

在需要修改的文件夾除創(chuàng)建一個js文件 ,通過 node .\****.js 運行或在創(chuàng)建一個.bat文件:node .****.js pause 后雙擊

記得修改dirName

// 引入 fs 文件系統(tǒng)模塊
let fs = require('fs')

const dirName = 'mus' // 讀取目標文件夾名稱
const reg = /(?<=[.])[a-z]+/ // 文件后綴 匹配規(guī)則

// 讀文件夾,獲取文件名列表
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)

// 循環(huán)當前文件名列表,根據(jù)需要重寫名字
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 = ''

  // 修改方式
  // 如果想根據(jù)不同條件,將文件分別放到不同的文件夾,按需更改 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}`);
  })
}

到此這篇關(guān)于JavaScript實現(xiàn)批量重命名文件的文章就介紹到這了,更多相關(guān)JavaScript重命名文件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Bootstrap 折疊(Collapse)插件用法實例詳解

    Bootstrap 折疊(Collapse)插件用法實例詳解

    這篇文章主要介紹了Bootstrap 折疊(Collapse)插件用法實例詳解的相關(guān)資料,需要的朋友可以參考下
    2016-06-06
  • Bootstrap Table使用整理(五)之分頁組合查詢

    Bootstrap Table使用整理(五)之分頁組合查詢

    這篇文章主要介紹了 Bootstrap Table使用整理(五)之分頁組合查詢的實例代碼,非常報錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-06-06
  • AJAX跨域請求json數(shù)據(jù)的實現(xiàn)方法

    AJAX跨域請求json數(shù)據(jù)的實現(xiàn)方法

    這篇文章介紹了AJAX跨域請求json數(shù)據(jù)的實現(xiàn)方法,有需要的朋友可以參考一下
    2013-11-11
  • JS得到當前時間的方法示例

    JS得到當前時間的方法示例

    這篇文章主要介紹了JS得到當前時間的方法,結(jié)合具體實例形式對比分析了javascript獲取日期時間的相關(guān)操作技巧,需要的朋友可以參考下
    2017-03-03
  • JavaScript常見繼承模式實例小結(jié)

    JavaScript常見繼承模式實例小結(jié)

    這篇文章主要介紹了JavaScript常見繼承模式,結(jié)合實例形式總結(jié)分析了javascript原型鏈繼承、構(gòu)造函數(shù)繼承、組合繼承、原型式繼承、寄生式繼承等相關(guān)實現(xiàn)技巧與操作注意事項,需要的朋友可以參考下
    2019-01-01
  • 原生js實現(xiàn)表格翻頁和跳轉(zhuǎn)

    原生js實現(xiàn)表格翻頁和跳轉(zhuǎn)

    這篇文章主要為大家詳細介紹了原生js實現(xiàn)表格翻頁和跳轉(zhuǎn),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-09-09
  • Bootstrap簡單實用的表單驗證插件BootstrapValidator用法實例詳解

    Bootstrap簡單實用的表單驗證插件BootstrapValidator用法實例詳解

    這篇文章主要介紹了Bootstrap簡單實用的表單驗證插件BootstrapValidator用法,結(jié)合實例形式詳細分析了Bootstrap表單驗證插件BootstrapValidator基本功能、原理、用法及操作注意事項,需要的朋友可以參考下
    2020-03-03
  • Javascript 事件流和事件綁定

    Javascript 事件流和事件綁定

    本文中的部分觀點參考至《Javascript高級程序設(shè)計》(很好的一本書,推薦大家看看?。琣ddEvent函數(shù)借鑒了YUI2.7的_addListener方法,這里也要謝謝YUI那些牛人,向他們致敬!
    2009-07-07
  • LayUI switch 開關(guān)監(jiān)聽 獲取屬性值、更改狀態(tài)的方法

    LayUI switch 開關(guān)監(jiān)聽 獲取屬性值、更改狀態(tài)的方法

    今天小編就為大家分享一篇LayUI switch 開關(guān)監(jiān)聽 獲取屬性值、更改狀態(tài)的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • Vue.js實現(xiàn)頁面后退時還原滾動位置的操作方法

    Vue.js實現(xiàn)頁面后退時還原滾動位置的操作方法

    Vuet看起來也不是很復雜,只需要定義好模塊狀態(tài),然后在組件中設(shè)置對應(yīng)的規(guī)則來更新模塊的狀態(tài)即可,這篇文章主要介紹了Vue.js實現(xiàn)頁面后退時還原滾動位置的實現(xiàn)方法,需要的朋友可以參考下
    2022-07-07

最新評論