激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

腳本之家,腳本語言編程技術(shù)及教程分享平臺!
分類導(dǎo)航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務(wù)器之家 - 腳本之家 - VBS - vbs腳本實現(xiàn)批量轉(zhuǎn)換文件編碼

vbs腳本實現(xiàn)批量轉(zhuǎn)換文件編碼

2020-08-13 11:15VBS腳本之家 VBS

這篇文章主要介紹了vbs腳本實現(xiàn)批量轉(zhuǎn)換文件編碼,可以批量對文件在Gb2312和UTF-8編碼間互相轉(zhuǎn)換,需要的朋友可以參考下

最近需要使用SourceInsight查看分析在Linux系統(tǒng)下開發(fā)的項目代碼,我們知道Linux系統(tǒng)中文本文件默認(rèn)編碼格式是UTF-8,而Windows中文系統(tǒng)中的默認(rèn)編碼格式是Gb2312。系統(tǒng)內(nèi)的編碼格式有所區(qū)別倒無傷大雅,關(guān)鍵的是SourceInsight竟不支持UTF-8,導(dǎo)致項目代碼內(nèi)的中文注釋全部亂碼!

既然SourceInsight不支持UTF-8編碼的文件,那我們就得想辦法將UTF-8的代碼文件轉(zhuǎn)化為GB2312編碼的。首先想到的是到網(wǎng)上搜一下“批量編碼轉(zhuǎn)換工具”,結(jié)果下載后發(fā)現(xiàn)編碼轉(zhuǎn)換后的文件總是出現(xiàn)亂碼,可能是工具的bug吧。既然不能使用工具轉(zhuǎn)換,那就自己寫一個程序進(jìn)行編碼轉(zhuǎn)換,但是細(xì)想一下覺得C++/java的編碼轉(zhuǎn)換程序?qū)懫饋碛直容^啰嗦,要是在Linux下寫一個shell腳本就能輕松搞定了。還好Windows下有vbs腳本可以幫助我們輕松達(dá)到這個目的。

復(fù)制代碼 代碼如下:


'-------------------------------------------------

 

'函數(shù)名稱:ReadFile

'作用:利用AdoDb.Stream對象來讀取各種格式的文本文件

'-------------------------------------------------

 

Function ReadFile(FileUrl, CharSet)

    Dim Str

    Set stm = CreateObject("Adodb.Stream")

    stm.Type = 2

    stm.mode = 3

    stm.charset = CharSet

    stm.Open

    stm.loadfromfile FileUrl

    Str = stm.readtext

    stm.Close

    Set stm = Nothing

    ReadFile = Str

End Function

 

我們使用ReadFile函數(shù)讀取文件,其中FileUrl指定文件的路徑,CharSet指定文件的原始編碼格式,使用adodb.stream對象讀取文件內(nèi)容到Str。

復(fù)制代碼 代碼如下:


'-------------------------------------------------

 

'函數(shù)名稱:WriteToFile

'作用:利用AdoDb.Stream對象來寫入各種格式的文本文件

'-------------------------------------------------

 

Function WriteToFile (FileUrl, Str, CharSet)

    Set stm = CreateObject("Adodb.Stream")

    stm.Type = 2

    stm.mode = 3

    stm.charset = CharSet

    stm.Open

    stm.WriteText Str

    stm.SaveToFile FileUrl, 2

    stm.flush

    stm.Close

    Set stm = Nothing

End Function

 

然后使用WriteToFile將Str寫回原文件FileUrl,并設(shè)定新的編碼CharSet。

復(fù)制代碼 代碼如下:


'-------------------------------------------------

 

'函數(shù)名稱:ConvertFile

'作用:將一個文件進(jìn)行編碼轉(zhuǎn)換

'-------------------------------------------------

 

Function ConvertFile(FileUrl)

    Call WriteToFile(FileUrl, ReadFile(FileUrl, SrcCode), DestCode)

End Function

 

這樣ConvertFile對上述兩個函數(shù)封裝,實現(xiàn)文件FileUrl的編碼轉(zhuǎn)換,其中原始編碼SrcCode與目的編碼DestCode為全局變量。

如果僅對一個文件進(jìn)行編碼轉(zhuǎn)換,我們不必這么大費(fèi)周章。我們希望能對任意的文件或文件夾內(nèi)的所有文件進(jìn)行編碼轉(zhuǎn)換,達(dá)到批量轉(zhuǎn)換的目的。

 

復(fù)制代碼 代碼如下:

'-------------------------------------------------

 

'函數(shù)名稱:ConvertDir

'作用:將任意目錄內(nèi)的文件進(jìn)行編碼轉(zhuǎn)換

'-------------------------------------------------

 

Function ConvertDir(DirUrl)

    If fs.FileExists(DirUrl) Then

       Call ConvertFile(DirUrl)

    Else

       Call SearchDir(DirUrl)

    End If

End Function

 

函數(shù)ConvertDir對任意路徑的文件/文件夾進(jìn)行編碼轉(zhuǎn)換,使用scripting.filesystemobject對象的FileExists函數(shù)判斷路徑對應(yīng)的是文件還是文件夾,如果是文件則直接調(diào)用ConvertFile進(jìn)行編碼轉(zhuǎn)換,否則調(diào)用SearchDir處理文件夾。

復(fù)制代碼 代碼如下:


'-------------------------------------------------

 

'函數(shù)名稱:SearchDir

'作用:遞歸查找目錄內(nèi)的文件,進(jìn)行編碼轉(zhuǎn)換

'-------------------------------------------------

 

Function SearchDir(path)  

    Set folder = fs.getfolder(path)

    Set subfolders = folder.subfolders

    Set Files = folder.Files  

    For Each i In Files

       Call ConvertFile(i.path)

    Next  

    For Each j In subfolders      

       Call SearchDir(j.path)

    Next

End Function

 

函數(shù)SearchDir是遞歸的,首先調(diào)用getfolder創(chuàng)建文件夾對象,然后取出文件夾內(nèi)的子文件夾集合subfolders和子文件集合files。對于每個子文件,直接調(diào)用ConvertFile進(jìn)行編碼轉(zhuǎn)換即可,而對于每個子文件夾,則遞歸調(diào)用SearchDir重復(fù)處理。

復(fù)制代碼 代碼如下:


'-------------------------------------------------

 

'設(shè)置編碼:默認(rèn) utf-8  --> gb2312

'-------------------------------------------------

 

SrcCode="utf-8"

DestCode="gb2312"

 

'-------------------------------------------------

'解析參數(shù)

'-------------------------------------------------

 

Set fs = CreateObject("scripting.filesystemobject")

Set objArgs = WScript.Arguments

If objArgs.Count>0 Then

    For I = 0 To objArgs.Count - 1

       FileUrl = objArgs(I)

       Call ConvertDir(FileUrl)

    Next

Else

    MsgBox "沒有文件/文件夾被拖入!"

    wscript.quit

End If

MsgBox "轉(zhuǎn)換成功!"

 

最后通過解析腳本文件的參數(shù),由于每個參數(shù)對應(yīng)一個文件/文件夾的路徑,將之傳遞給ConvertDir即可。這里默認(rèn)的是將UTF-8編碼轉(zhuǎn)化為GB2312編碼,讀者可以根據(jù)自身需要自行修改。

將上述代碼保存為ConvertCode.vbs,只需要將任意多個文件選中拖動到該腳本文件上即可。或者使用命令行。

復(fù)制代碼 代碼如下:

> ConvertCode.vbs [filepath]

 

需要注意的是文件編碼是就地轉(zhuǎn)換的,在轉(zhuǎn)換之前最好將原文件/文件夾進(jìn)行備份。

最后附上腳本文件的所有代碼。

復(fù)制代碼 代碼如下:


'/*===========================================================
' * Intro        把要轉(zhuǎn)換的多個文件/文件夾拖到該文件上即可
' * FileName     ConvertCode.vbs
' * Author       Florian
' * Version      v1.0
' * LastModify  2014-06-11 00:39:58
' *==========================================================*/

 

'-------------------------------------------------
'設(shè)置編碼:默認(rèn)    utf-8    -->    gb2312
'-------------------------------------------------

SrcCode="utf-8"
DestCode="gb2312"

'-------------------------------------------------
'解析參數(shù)
'-------------------------------------------------

Set fs = CreateObject("scripting.filesystemobject")
Set objArgs = WScript.Arguments
If objArgs.Count>0 Then
    For I = 0 To objArgs.Count - 1
        FileUrl = objArgs(I)
        Call ConvertDir(FileUrl)
    Next
Else
    MsgBox "沒有文件/文件夾被拖入!"
    wscript.quit
End If
MsgBox    "轉(zhuǎn)換成功!"

'-------------------------------------------------
'函數(shù)名稱:ConvertDir
'作用:將任意目錄內(nèi)的文件進(jìn)行編碼轉(zhuǎn)換
'-------------------------------------------------

Function ConvertDir(DirUrl)
    If fs.FileExists(DirUrl) Then 
        Call ConvertFile(DirUrl)
    Else
        Call SearchDir(DirUrl)
    End If
End Function


'-------------------------------------------------
'函數(shù)名稱:SearchDir
'作用:遞歸查找目錄內(nèi)的文件,進(jìn)行編碼轉(zhuǎn)換
'-------------------------------------------------

Function SearchDir(path)   
    Set folder = fs.getfolder(path)
    Set subfolders = folder.subfolders
    Set Files = folder.Files   
    For Each i In Files
        Call ConvertFile(i.path)
    Next   
    For Each j In subfolders       
        Call SearchDir(j.path)
    Next
End Function

'-------------------------------------------------
'函數(shù)名稱:ConvertFile
'作用:將一個文件進(jìn)行編碼轉(zhuǎn)換
'-------------------------------------------------

Function ConvertFile(FileUrl)
    Call WriteToFile(FileUrl, ReadFile(FileUrl, SrcCode), DestCode)
End Function

'-------------------------------------------------
'函數(shù)名稱:ReadFile
'作用:利用AdoDb.Stream對象來讀取各種格式的文本文件
'-------------------------------------------------

Function ReadFile(FileUrl, CharSet)
    Dim Str
    Set stm = CreateObject("Adodb.Stream")
    stm.Type = 2
    stm.mode = 3
    stm.charset = CharSet
    stm.Open
    stm.loadfromfile FileUrl
    Str = stm.readtext
    stm.Close
    Set stm = Nothing
    ReadFile = Str
End Function

'-------------------------------------------------
'函數(shù)名稱:WriteToFile
'作用:利用AdoDb.Stream對象來寫入各種格式的文本文件
'-------------------------------------------------

Function WriteToFile (FileUrl, Str, CharSet)
    Set stm = CreateObject("Adodb.Stream")
    stm.Type = 2
    stm.mode = 3
    stm.charset = CharSet
    stm.Open
    stm.WriteText Str
    stm.SaveToFile FileUrl, 2
    stm.flush
    stm.Close
    Set stm = Nothing
End FunctionView Code

 

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 爱逼av| 午夜人体 | 精品视频 久久久 | 欧美77| 久久久国产精品免费观看 | 91视频久久 | 成人一级视频在线观看 | 成人免费精品视频 | 午夜精品福利视频 | 最新se94se在线欧美 | 久久噜噜噜精品国产亚洲综合 | 亚洲精品一区国产精品丝瓜 | 天天草夜夜骑 | 久久综合久久综合久久综合 | 九九热精品免费视频 | 成人国产在线视频 | 亚洲第五色综合网 | 成人免费视频 | 国产精品久久久久久久久久东京 | 九九色在线观看 | 欧美国产一区二区三区 | 欧美一级高清片 | 中文欧美日韩 | 久久精品国产亚洲7777 | 欧美成年性h版影视中文字幕 | 欧美在线a| 久久av免费 | 日本爽快片100色毛片视频 | 欧美黄色一级片视频 | 国产韩国精品一区二区三区久久 | 久久久综 | 中文字幕精品一二三四五六七八 | 国产一区二区三区在线免费 | 欧美三级欧美成人高清www | 免费中文视频 | 性色吧 | 91精品国 | 国产精品1区2区 | 国产激情精品一区二区三区 | 欧美日韩色 | 成年毛片 |