1. 程式人生 > >VB實現批量名稱修改

VB實現批量名稱修改

前陣子寫了一個目錄名/檔名的獲取小程式,這兩天居然又被名稱批量修改麻煩了一下,所以再寫一個吧。

注意:你要是隻想寫一次的話,用批處理更方便。只有多次使用的情況下,自己寫程式才有意義。

VB中進行名稱修改很容易,用到的就是Name這個函式,用法如下:


Name OldName As NewName,它不僅可以改寫名稱,而且可以更改目錄,比如:

Name "c:/CAN1ED.txt" As "c:/test/CAN01ED.txt"


Private Sub Command1_Click() '批量改名
Dim Successstr As String
Dim Successnum As Integer

Dim pathname As String

Dim sf As String
Dim len1, len2, len3 As Integer

Successnum = 0

'比如原檔案是有如下幾個
'C:/test/【老爸老媽的浪漫史.第三季】.[How.I.Met.Your.Mother][S0301][Chi-Eng][TVrip][624×352].rmvb
'C:/test/【老爸老媽的浪漫史.第三季】.[How.I.Met.Your.Mother][S0302][Chi-Eng][TVrip][624×352].rmvb
'C:/test/【老爸老媽的浪漫史.第三季】.[How.I.Met.Your.Mother][S0303][Chi-Eng][TVrip][624×352].rmvb


'分成如下的三個部分:(text3的??指的是01/02/03這些準備保留的數字)
'text2:C:/test/【老爸老媽的浪漫史.第三季】.[How.I.Met.Your.Mother][S03
'text3:??
'text4:[Chi-Eng][TVrip][624×352].rmvb

len1 = Len(text2) '原檔案的前部分字數
len2 = Len(text3) '原檔案的需要保留的數字或者字母
len3 = Len(text4) '原檔案的後半段字數

If Right(Text1, 1) <> "/" Then
    pathname = Text1 & "/"
Else
    pathname = Text1
End If

sf = Dir(pathname & "*.*")
Dim tempss As String
Do While sf <> ""
    If Left$(sf, len1) = Text2 And Len(sf) = len1 + len2 + len3 Then '左側匹配
        tempss = Left$(sf, len1 + len2)
        tempss = Right$(tempss, len2)
        Name pathname & sf As pathname & Text5 & tempss & Text7
        Successnum = Successnum + 1
        Successstr = Successstr & sf & vbCrLf
    End If
sf = Dir()
Loop

If Successnum > 0 Then
    MsgBox "成功修改" & Successnum & "個檔案:" & vbCrLf & Successstr
Else
    MsgBox "沒有找到匹配項:" & vbCrLf & Text2 & "??" & Text4
End If
End Sub

下面再簡單介紹下用法吧,看看截圖,也許大家就可以明白怎麼用了:

如圖上的用法,就是將
E:/批量改名測試/[Mother][S0301][624×352].rmvb  改為了  01.rmvb
E:/批量改名測試/[Mother][S0302][624×352].rmvb  改為了  02.rmvb
E:/批量改名測試/[Mother][S0303][624×352].rmvb  改為了  03.rmvb


這回大家看明白了吧。呵呵


批量改名