假設某個程式可排程自動備份Log或資料,但沒有像 SQL Srv 可在管理維護計畫中,刪除檔案存在的時間,若檔案很大且一直產出,日積月累硬碟就會被塞爆了,因此可寫個 bat 批次檔,在伺服器閒置時排程去K掉它。
批次檔內容要如何寫? C:\Users\nico>FORFILES /?
FORFILES [/P pathname] [/M searchmask] [/S] [/C command] [/D [+ | -] {yyyy/MM/dd | dd}]
描述:
選取一個檔案 (或一組檔案),並在檔案上執行命令。這對批次工作很有幫助。
參數清單:
/P pathname 表示要開始搜尋的路徑。預設資料夾是目前的目錄 (.)。
/M searchmask 根據 searchmask 搜尋檔案。預設的 searchmask 是 '*'。
/S 指示 forfiles 遞迴搜尋子目錄。例如 "DIR /S"。
/C command 表示每個檔案要執行的命令。
命令字串應該包含在雙括號之間。
預設的命令是 "cmd /c echo @file"。
下列變數可以使用於命令字串:
@file - 傳回檔案的名稱。
@fname - 只傳回檔案的名稱,不傳回副檔名。
@ext - 只傳回檔案的副檔名。
@path - 傳回檔案的完整路徑。
@relpath - 傳回檔案的相對路徑。
@isdir - 如果檔案類型是目錄的話,傳回 "TRUE",如果是檔案的話,傳回 "FALSE"。
@fsize - 傳回檔案的大小,單位是位元組。
@fdate - 傳回檔案上次修改的日期。
@ftime - 傳回檔案上次修改的時間。
要在命令列中包含特殊字元的話,請使用 0xHH 格式的十六進位字元碼 (例如 0x09 代表 tab)。
內部的 CMD.exe 命令應該以 "cmd /c" 執行。
/D date 選取檔案上次修改的時間大於或等於 (+) 、小於或等於 (-),使用 "yyyy/MM/dd" 格式指定的日期;或選取檔案上次修改的時間大於或等於 (+)
目前的日期再加上 "dd" 天、小於或等於 (-) 目前的日期減去 "dd" 天。
有效的 "dd" 可以是介於 0 - 32768 之間的數字。
如果未指定,"+" 將被視為預設符號。
範例:
FORFILES /?
FORFILES
FORFILES /P C:\WINDOWS /S /M DNS*.*
FORFILES /S /M *.txt /C "cmd /c type @file | more"
FORFILES /P C:\ /S /M *.bat
FORFILES /D -30 /M *.exe /C "cmd /c echo @path 0x09 was changed 30 days ago"
FORFILES /D 2001/01/01 /C "cmd /c echo @fname is new since Jan 1st 2001"
FORFILES /D +2020/5/22 /C "cmd /c echo @fname is new today"
FORFILES /M *.exe /D +1
FORFILES /S /M *.doc /C "cmd /c echo @fsize"
FORFILES /M *.txt /C "cmd /c if @isdir==FALSE notepad.exe @file"
列出 D:\capture 底下超過 30 天的 *.jpg 檔案(含子目錄)
FORFILES /P "D:\capture" /M "*.jpg" /S /C "cmd /c echo @path" /D -30
刪除 C:\backup\CardSQL 底下超過 10 天的 *.bak 檔案(不處理子目錄)
FORFILES /P "D:\backup\CardSQL\" /M "*.bak" /C "cmd /c del @path" /D -10
沒有留言:
張貼留言