Windows定时删除某天前文件的批处理脚本

备注:
1.如XP下因为没有forfiles.exe,拷贝windows2003下的forfiles.exe文件到XP的system32目录即可使用forfiles命令。 

2.该文档适用于windows客户端操作系统xp win7/8/10,windows服务器端操作系统 server 2003/2008/2012/2016。
3.如有错漏,烦劳指出,谢谢!


forfiles.exe及帮助

描述:

    选择一个文件(或一组文件)并在那个文件上执行一个命令。这有助于批处理作业。

语法:

forfiles /p <目标目录名> /d <天数> /c <执行的命令>

1.看看列出的三个参数都有什么用处:(简单解析)

/p  指定了要在哪个目录里查找文件,默认是当前工作目录。 

/d  指定一个日期或天数,用于比较文件的最后修改日期是否符合条件。 

/c  对每个找到的文件执行的命令。

2.看看列出的三个参数都有什么用处:(详细解析)

/p <Path>     : 指定开始搜索文件的位置,如果不指定则默认为当前目录。

/m <SearchMask> : 文件查找所使用的通配符如代码中的"*.log"则为所有日志文件,当然也可以指定诸如"manmee_*.log"这样以manmee开头的所有日志文件。如果不指定此参数则默认为"*.*"。

/d [{+|-}][{<Date>|<Days>}] : 指定想选择文件的最后修改时间,上文中用了 "/d -7" 表示所有以当天为基础,7天以前的文件。

当然这里还可以指定具体时间,例如:"/d -08/18/2009"这样所有早于2009年8月18日的文件。注意指定的时间必须是"MM/DD/YYYY"的格式。

/c 对所有文件以此执行指定的命令,命令体须在双引号(")内,默认是"cmd /c echo @file"。上文中用到的是"cmd /c del /f @path"删除指定文件。(这里的@file 和 @path 为变量,下文中将进行解释。

====================例子说明==========================

例1.要把在C盘根目录下最后修改日期大于或等于2007年7月1日的文件复制到D盘根目录下

forfiles /p "c:\" /d "2007-7-1" /c "cmd /c copy @path d:\"

例2.1 删除在C盘backup目录下最后修改日期在10天前的文件

forfiles /p "c:\backup" /d -10 /c "cmd /c echo deleting @file ... && del /f @path"

例2.2 自动删除D盘test目录最后修改日期在7天前文件

forfiles /p "d:\test" /s /m *.* /d -7 /c "cmd /c del @path"

例2.3 删除当前目录下28天以前的扩展名为bkf文件(以当前系统时间为基准)

forfiles /m *.bkf /d -28 /c "cmd /c del @file /f"

删除文件的语法解析
forefiles /p /m -d /c

forfiles /p 包含要删除文件的完整路径(如:F:\Logfiles) /m *.log -d -7 /c "cmd /c del /f @path"

解释一下相关参数及命令

@PATH : 表示文件的完整的路径。

@File : 表示文件名称。

==========案例操作============

1.删除所有的空目录(以删除d:\test目录下为例)

dir /ad/b/s d:\test\ |sort /r >d:\kill.txt

For /f "tokens=*" %%i in (d:\kill.txt) DO rd "%%i"

del d:\kill.txt

2.自动删除7天前文件和目录

{建一个bat文件的快捷方式在启动,d:\test换成你要的目录路径。日期是指修改的日期。 }

原理:先删过期文件,再删所有的空目录,这才是一个完整的删除过程 

@echo off

forfiles /p "d:\test" /s /m *.* /d -7 /c "cmd /c del @path"

dir /ad/b/s d:\test\ |sort /r >d:\kill.txt

For /f "tokens=*" %%i in (d:\kill.txt) DO rd "%%i"

del d:\kill.txt

原文地址:http://blog.51cto.com/8852184/2083368

时间: 2024-08-25 22:01:44

Windows定时删除某天前文件的批处理脚本的相关文章

windows 定时删除N天前日志脚本

删除目录/P 表示目录/S 表示递归向下查询子目录/D 表示date -460 意思是460天以前 或者 -2018/11/9 表示这个日期以前的/C 开始执行命令 内部还有一个cmd @ISDIR==TRUE 表示判断是不是目录RD 表示删除目录(文件夹)/s 表示可以删除非空的文件夹 /q 安静模式,不需要停下来回应是否因该删除 示例: E:\data\bpt\log\ABC>FORFILES /P E:\data\bpt\log /S /D -460 /C "cmd /c if @I

python脚本删除n天前文件可用于windows,linux并且支持跨平台

脚本如下: #!/usr/local/python/bin/python # -*-coding=utf8 -*- import time import os, sys # 设置删除多少天前的文件 N = 3 #要删除路径 path = r'/tmp/wry/abc' def deletefile(path): for eachfile in os.listdir(path): filename = os.path.join(path, eachfile) if os.path.isfile(f

mysql定时删除当前时间前分钟的数据

mysql定时删除当前时间前分钟的数据 2013-01-31      0个评论       作者:上官车月 收藏    我要投稿 mysql定时删除当前时间前分钟的数据 Sql代码  www.2cto.com SET GLOBAL event_scheduler = ON; delimiter $$ drop event if exists e_wom_stat; create event e_wom_stat on schedule EVERY 1 day STARTS '2013-01-0

MySQL定时任务event,储存过程(定时删除指定时间前90天指定表的数据)

MySQL定时任务event,储存过程(定时删除指定时间前90天指定表的数据) 分类: MySql5.x2014-06-23 15:16 1266人阅读 评论(0) 收藏 举报 mysql数据库 [sql] view plaincopy <span style="font-family: 'Microsoft YaHei'; font-size: 14px;">MySQL定时任务event</span> 由于一些业务需求,我们可能需要定时清除数据库一些废弃的数据

Debian下自动备份文件并上传到远程FTP服务器且删除指定日期前的备份Shell脚本

说明:  1.备份目录/home/osyunwei下面所有的文件到/home/osyunweibak里面,并且保存为osyunwei20120701.tar.gz的压缩文件格式(2012_07_01是指备份执行时当天的日期),最后只保留最近7天的备份 2.上传/home/osyunweibak里面的备份文件到远程FTP服务器上,并且只保留最近7天的备份. 3.FTP服务器:192.168.21.139 端口:21 账号:osyunwei 密码:123456 osyunweibak为备份文件存放目

Windows 定时删除指定路径下N天前的日志文件

Windows 下bat脚本文件的内容为 1. 删除指定路径下5天前的所有文件 . @echo off set SrcDir=E:\WORK\Git set DaysAgo=5 forfiles /p %SrcDir% /s /m *.*/d -%DaysAgo% /c "cmd /c del /f /q /a @path" 2.删除指定路径下5天前的所有log文件 @echo off set SrcDir=E:\WORK\Git //指定的路径 :5天前 set DaysAgo=5 

Windows自动删除n天前的文件的批处理脚本

数据库每天备份文件,然而只需要保留七天的备份即可,编写一个批处理脚本文件自动删除七天前的文件并设置定时任务 自动删除文件需要用到forfiles命令 forfiles参数:/p 指定的路径/s 包括子目录/m 查找的文件名掩码/d 指定日期,有绝对日期和相对日期, 此处-7指当前日期 的7天前   /c 运行的命令行   表示为每个文件执行的命令.命令字符串应该用双引号括起来. 默认命令是 "cmd /c echo @file".下列变量 可以用在命令字符串中: @file    -

oracle 定时删除3天前的备份数据

不需要保留那么多,按公司要求只需要保留一个星期的即可. 1.那么有什么方法自动删除7天以前备份的*.log文件呢? 2.服务器过多,不可能一一手动创建,有没有自动完成这个创建计划任务的批处理呢? 首先要解决的是自动删除7天以前备份的log文件,然后创建一个可以自动创建一个每 周指定日期指定时间运行一次该自动删除的批处理 一:删除7天以前备份的文件 命令 FORFILES [/P pathname] [/M searchmask] [/S]         [/C command] [/D [+

forfiles命令批量删除N天前文件

在整理手上几台SQL SERVER 2000的数据库备份时,一方面为了方便快速还原数据库,另外一方面为了备份冗余.备份方式统一(先备份到本地,然后收上磁带),将以前通过Symantec Backup Exec直接备份上带的作业改成了如下方式: Step 1: 通过数据库维护计划将备份生成在本地磁盘M,完整备份保留2天,事务日志备份保留3天 M:\DB_BACKUP\FULL_BACKUP M:\DB_BACKUP\LOG_BACKUP Step 2:  备份完成后通过Symantec Backu