标题: [原创] VBS实现文件夹/文件补0重命名 [打印本页]
作者: 老刘1号 时间: 2019-4-23 19:10 标题: VBS实现文件夹/文件补0重命名
隔壁发去重复,我也来水一贴,
会给目录下的所有文件名/文件夹名中出现的第一个数字补0。
用法:存vbs,要处理的文件/文件夹的父目录拖上去。
文件补0重命名.vbs- Rem Code by OldLiu
- Option Explicit
- Dim fso,Files
- Set fso = CreateObject("Scripting.FileSystemObject")
- If wsh.Arguments.Count <> 1 Then wsh.Quit
- Set Files = fso.GetFolder(wsh.Arguments(0)).Files
-
- Dim regex
- Set regex = New RegExp
- regex.Global = False
- regex.Pattern = "\D*(\d+)"
-
- Rem 得到最大索引
- Dim File,lngMaxIndex,strMatch
- lngMaxIndex = 0
- For Each File In Files
- For Each strMatch In regex.Execute(File.Name)
- If CLng(strMatch.Submatches(0)) > lngMaxIndex Then
- lngMaxIndex = CLng(strMatch.Submatches(0))
- End If
- Next
- Next
- If lngMaxIndex = 0 Then wsh.Quit 1
-
- Rem 计算最大补0数目
- Dim bytMaxZeroAdd
- bytMaxZeroAdd = Len(CStr(lngMaxIndex))
-
- Rem 重命名处理
- regex.Pattern = "(\D*)(\d+)(.*)"
- For Each File In Files
- For Each strMatch In regex.Execute(File.Name)
- File.Move _
- File.ParentFolder&"\"& _
- strMatch.Submatches(0) & _
- String(bytMaxZeroAdd - Len(CStr(CLng(strMatch.Submatches(1)))),"0") & _
- CStr(CLng(strMatch.Submatches(1))) & _
- strMatch.Submatches(2)
- Next
- Next
复制代码
文件夹补0重命名.vbs- Rem Code by OldLiu
- Option Explicit
- Dim fso,Folders
- Set fso = CreateObject("Scripting.FileSystemObject")
- If wsh.Arguments.Count <> 1 Then wsh.Quit
- Set Folders = fso.GetFolder(wsh.Arguments(0)).SubFolders
-
- Dim regex
- Set regex = New RegExp
- regex.Global = False
- regex.Pattern = "\D*(\d+)"
-
- Rem 得到最大索引
- Dim Folder,lngMaxIndex,strMatch
- lngMaxIndex = 0
- For Each Folder In Folders
- For Each strMatch In regex.Execute(Folder.Name)
- If CLng(strMatch.Submatches(0)) > lngMaxIndex Then
- lngMaxIndex = CLng(strMatch.Submatches(0))
- End If
- Next
- Next
- If lngMaxIndex = 0 Then wsh.Quit 1
-
- Rem 计算最大补0数目
- Dim bytMaxZeroAdd
- bytMaxZeroAdd = Len(CStr(lngMaxIndex))
-
- Rem 重命名处理
- regex.Pattern = "(\D*)(\d+)(.*)"
- For Each Folder In Folders
- For Each strMatch In regex.Execute(Folder.Name)
- Folder.Move _
- Folder.ParentFolder&"\"& _
- strMatch.Submatches(0) & _
- String(bytMaxZeroAdd - Len(CStr(CLng(strMatch.Submatches(1)))),"0") & _
- CStr(CLng(strMatch.Submatches(1))) & _
- strMatch.Submatches(2)
- Next
- Next
复制代码
欢迎光临 批处理之家 (http://bbs.bathome.net/) |
Powered by Discuz! 7.2 |