午夜国产狂喷潮在线观看|国产AⅤ精品一区二区久久|中文字幕AV中文字幕|国产看片高清在线

    使用腳本自動(dòng)壓縮指定目標(biāo)下的所有文件的代碼
    來(lái)源:易賢網(wǎng) 閱讀:1409 次 日期:2016-07-05 11:39:27
    溫馨提示:易賢網(wǎng)小編為您整理了“使用腳本自動(dòng)壓縮指定目標(biāo)下的所有文件的代碼”,方便廣大網(wǎng)友查閱!

    為了解決這類(lèi)問(wèn)題,我使用Visual Basic Scripting設(shè)計(jì)了一個(gè)腳本,可以自動(dòng)達(dá)到這個(gè)目標(biāo)。在本腳本中,自動(dòng)壓縮所有文件。為了避免將腳本自己也壓縮進(jìn)去,使用了一些判斷。

    代碼如下:

    call main()

    Sub main()

    Dim fs '文件系統(tǒng)。

    Dim f 'folder

    Dim fc 'files

    Dim s 'string

    Dim ws 'SHELL。

    Dim subfs

    Dim fi

    '創(chuàng)建SHELL。

    Set ws = CreateObject("WScript.Shell")

    '創(chuàng)建文件對(duì)象。

    Set fs = CreateObject("Scripting.FileSystemObject")

    Set f = fs.GetFolder(ws.currentdirectory)

    Handle_files(ws.currentdirectory)

    Set subfs = f.SubFolders

    '遍歷每個(gè)子目錄。

    For Each fi In subfs

    Call ListSub(fi.Path)

    Next

    End Sub

    Sub ListSub(filename)

    On Error Resume Next

    Dim subfs '子目錄。

    '首先處理當(dāng)前目錄。

    Handle_Files(filename)

    '創(chuàng)建文件對(duì)象。

    Set fs = CreateObject("Scripting.FileSystemObject")

    Set f = fs.GetFolder(filename)

    Set subfs = f.SubFolders

    For Each fi In subfs

    Call ListSub(fi.Path)

    Next

    End Sub

    '處理每個(gè)目錄下的文件。

    Sub Handle_Files(foldername)

    '創(chuàng)建文件對(duì)象。

    Set fs = CreateObject("Scripting.FileSystemObject")

    Set f = fs.GetFolder(foldername)

    Set fc = f.Files

    '創(chuàng)建SHELL。

    Set ws = CreateObject("WScript.Shell")

    '遍歷文件對(duì)象。

    For Each fl In fc

    if ((instr(fl.Name,"vbs") = 0) and (instr(fl.Name,"rar") = 0)) then

    '進(jìn)行壓縮。

    s = "winrar M -ep " & fl.Path & ".rar " & fl.Path

    ws.Run s, 0, True

    End If

    Next

    End Sub

    sub output(string)

    wscript.echo string

    end sub

    一種更加巧妙的方法

    對(duì)上個(gè)腳本稍加改動(dòng),使用正則表達(dá)式(Regular Expression ),可以方便我們的判斷過(guò)程。修改后的腳本程序如下所示。注意我們這里排除的是不壓縮的文件類(lèi)型。

    代碼如下:

    call main()

    Sub main()

    Dim fs '文件系統(tǒng)。

    Dim f 'folder

    Dim fc 'files

    Dim s 'string

    Dim ws 'SHELL。

    Dim subfs

    Dim fi

    '創(chuàng)建SHELL。

    Set ws = CreateObject("WScript.Shell")

    '創(chuàng)建文件對(duì)象。

    Set fs = CreateObject("Scripting.FileSystemObject")

    Set f = fs.GetFolder(ws.currentdirectory)

    Handle_files(ws.currentdirectory)

    Set subfs = f.SubFolders

    '遍歷每個(gè)子目錄。

    For Each fi In subfs

    Call ListSub(fi.Path)

    Next

    End Sub

    Sub ListSub(filename)

    On Error Resume Next

    Dim subfs '子目錄。

    '首先處理當(dāng)前目錄。

    Handle_Files(filename)

    '創(chuàng)建文件對(duì)象。

    Set fs = CreateObject("Scripting.FileSystemObject")

    Set f = fs.GetFolder(filename)

    Set subfs = f.SubFolders

    For Each fi In subfs

    Call ListSub(fi.Path)

    Next

    End Sub

    '處理每個(gè)目錄下的文件。

    Sub Handle_Files(foldername)

    '創(chuàng)建文件對(duì)象。

    Set fs = CreateObject("Scripting.FileSystemObject")

    Set f = fs.GetFolder(foldername)

    Set fc = f.Files

    '創(chuàng)建SHELL。

    Set ws = CreateObject("WScript.Shell")

    '遍歷文件對(duì)象。

    For Each fl In fc

    if ( RegExpTest(".vbs|.rar|.zip",fl.name) = false) then

    '進(jìn)行壓縮。

    s = "winrar M -ep " & fl.Path & ".rar " & fl.Path

    output s

    ws.Run s, 0, True

    End If

    Next

    End Sub

    sub output(string)

    wscript.echo string

    end sub

    '使用正則表達(dá)式進(jìn)行判斷。

    Function RegExpTest(patrn, strng)

    Dim regEx, retVal ' Create variable.

    Set regEx = New RegExp ' Create regular expression.

    regEx.Pattern = patrn ' Set pattern.

    regEx.IgnoreCase = False ' Set case sensitivity.

    retVal = regEx.Test(strng) ' Execute the search test.

    If retVal Then

    RegExpTest = true

    Else

    RegExpTest = false

    End If

    End Function

    更多信息請(qǐng)查看腳本欄目
    由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢(xún)回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門(mén)公布的正式信息和咨詢(xún)?yōu)闇?zhǔn)!

    2025國(guó)考·省考課程試聽(tīng)報(bào)名

    • 報(bào)班類(lèi)型
    • 姓名
    • 手機(jī)號(hào)
    • 驗(yàn)證碼
    關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢(xún) | 簡(jiǎn)要咨詢(xún)須知 | 新媒體/短視頻平臺(tái) | 手機(jī)站點(diǎn) | 投訴建議
    工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
    云南網(wǎng)警備案專(zhuān)用圖標(biāo)
    聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢(xún)關(guān)注公眾號(hào):hfpxwx
    咨詢(xún)QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
    云南網(wǎng)警報(bào)警專(zhuān)用圖標(biāo)