一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

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

服務器之家 - 腳本之家 - VBS - 使用vbs腳本定時刪除N天前的文件

使用vbs腳本定時刪除N天前的文件

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

腳本放在定時任務里代替服務定時執行一些操作比較方便,下面是實現刪除文件夾下N天前創建的文件的vbs腳本

腳本放在定時任務里代替服務定時執行一些操作比較方便,下面是實現刪除文件夾下N天前創建的文件的vbs腳本,在配置文件 DelFolderList.txt 中配置要刪除的文件路徑,ONLY-DEL-FILES 下的路徑 是只刪除其下的文件,不刪除其內的子目錄的文件。DEL-FOLDER-FILES下的路徑 是刪除其內文件及其子目錄內的文件,子目錄為空時刪除目錄,刪除的文件list 放在log文件夾內。例配置文件DelFolder.txt 內容如下:

ONLY-DEL-FILES
E:\Code\test
DEL-FOLDER-FILES
E:\Code\subfolder

腳本內容:

 

復制代碼 代碼如下:


Option Explicit
dim mFSO    '定義文件系統對象
dim wFSO    '定義文件系統對象
DIM filecount '文件計數
dim foldercount '文件夾計數

 

dim fstream    '定義讀文件流對象
dim wstream    '定義寫文件流對象

dim folder    '文件夾對象
dim rootfolder    '文件夾對象
dim file    '文件對象
dim Subdirs     '文件夾集合對象
dim subdir        '文件夾對象
dim LoopFolder    '文件夾對象
dim dopath    '路徑字符串

Dim delFlag
delFlag =0  ' 0: 不刪除子目錄   ,1:刪除子目錄

DIM WSH
SET WSH=WSCRIPT.CreateObject("WSCRIPT.SHELL")'擊活WScript.Shell對象
main()

sub main()
dim filename
filecount = 0
foldercount = 0
Set mFSO = CreateObject("Scripting.FileSystemObject")
Set wFSO = CreateObject("Scripting.FileSystemObject")
Set fstream = mFSO.OpenTextFile("DelFolderList.txt", 1)
filename=Cstr(Date)
filename=filename + "_" + Replace(Cstr(Time),":","_")
Set wstream = wFSO.CreateTextFile("log\" & filename & ".log", TRUE)
'循環讀取一行filelist.txt中的內容
Do While True <> fstream.AtEndOfStream
   dopath = fstream.ReadLine
   If dopath = "ONLY-DEL-FILES" Then
      delFlag =0
   If True <> fstream.AtEndOfStream Then
   dopath = fstream.ReadLine
   End If
   End If

   If dopath = "DEL-FOLDER-FILES" Then
      delFlag =1
   If True <> fstream.AtEndOfStream Then
        dopath = fstream.ReadLine
   End if
   End If

   if mFSO.FolderExists(dopath) Then
       If 1 = delFlag Then ' 刪除子目錄

       set rootfolder=mFSO.GetFolder(dopath)
       wstream.WriteLine(rootfolder.path & " 下刪除了以下文件:")
       del_file_subFolder rootfolder
       wstream.WriteLine(rootfolder.path & " 下刪除了以下文件夾:")
       del_folderFunc rootfolder
    'del_folderFunc rootfolder
        wstream.WriteBlankLines(1) 
   Else '只刪除文件
     set rootfolder=mFSO.GetFolder(dopath)
        wstream.WriteLine(rootfolder.path & " 下刪除了以下文件:")
        del_file rootfolder
        wstream.WriteBlankLines(1)
   End If
   else
        WSH.POPUP("文件夾“" & dopath &"”不存在或路徑錯誤")
        wstream.WriteLine("文件夾“" & dopath &"”不存在或路徑錯誤")
    end if
Loop
fstream.Close
    

'WSH.POPUP("共刪除文件" & filecount & "個、文件夾" & foldercount & "個")
end sub

sub del_file(folder)
    dim df        '標記
    For Each file In folder.files
        df=DateDiff("d",file.DateCreated,Now)
        If (df>1) Then '1天前的文件
            wstream.WriteLine(folder.path & "\" & file.Name & vbTab & file.DateCreated)
            file.Delete()
            filecount=filecount+1
        End If
    Next
end Sub

''刪除文件 同時刪除subfolder
sub del_file_subFolder(folder)
    dim df        '標記
    For Each file In folder.files
        df=DateDiff("d",file.DateCreated,Now)
        If (df>1) Then
            wstream.WriteLine(folder.path & "\" & file.Name & vbTab & file.DateCreated)
            file.Delete()
            filecount=filecount+1
        End If
    Next
    '遞歸調用del_file函數,實現子目錄文件的遍歷刪除
    If (0 < Folder.SubFolders.Count ) then
        For Each loopfolder in folder.SubFolders
        del_file_subFolder loopfolder
        Next
    End If
end sub


sub del_folderFunc(folder)
    dim loopsub
    dim tmp
    if 0=folder.subfolders.Count Then    '判斷其下是否還有子文件夾,若無
        if 0=folder.files.Count then    '如果其下還有文件則退出(符合條件的文件上一步已刪掉了)
            if Ucase(folder.path)<>Ucase(dopath) then    '判斷是否為根目錄,是則退出,不是則刪除
                wstream.WriteLine(folder.path & vbTab & folder.DateCreated)
                folder.delete
                foldercount=foldercount+1
                 '' del_folderFunc(mFSO.GetFolder(delFolderPath))        '刪除該文件夾后從根目錄重新檢查,以檢查其父目錄是否該刪除
            end if
        End if
    else
        For Each subdir In folder.subfolders    '還有子文件夾則輪循每一個子文件夾
            del_folderFunc(subdir)
        Next
    End if

end sub

 

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 奇米影视亚洲狠狠色 | 精品视频在线免费 | 麻豆视频免费在线观看 | 国产在线观看a | 调教催眠改造np总攻 | 亚洲娇小性hd | 亚洲女性色尼古综合网 | 免费xxxx日本大片在线观看 | 艾秋麻豆果冻剧传媒在线播放 | 国色天香社区在线视频播放 | 亚洲成人贴图 | www.一级片.com| 国产高清日韩 | 99视频有精品视频免费观看 | 欧美一区不卡二区不卡三区 | 小小水蜜桃视频高清在线观看免费 | 微拍秒拍99福利精品小视频 | 性欧美videofree中文字幕 | 午夜伦伦电影理论片大片 | 日本96在线精品视频免费观看 | 国产精品久久久久久久免费大片 | 亚洲国产精品综合一区在线 | 亚洲精品国产精品精 | 成年美女黄网色大观看全 | 午夜爱爱爱爱爽爽爽视频网站 | 亚洲 日韩 国产 中文视频 | 国产一区二区三区欧美 | 日韩美毛片 | 亚洲 日韩 自拍 视频一区 | 日韩一区二区三区四区不卡 | 五月色婷婷久久综合 | 免费的强动漫人物的 | 关晓彤一级做a爰片性色毛片 | 国产香蕉97碰碰久久人人 | 国产精品美女久久久久网站 | 美妇在线| 国产综合色在线视频区色吧图片 | ferr孕妇videos毛茸茸 | 午夜勾魂曲 | 国产成人一区二区三区影院免费 | 小向美奈子av |