forfiles结合域控定期删除文件

forfiles结合域控定期删除文件

要做到根据文件时间来删除文件,有一个命令非常好,就是forfiles

我的脚本内容如下,删除桌面和下载目录上的docx和xlsx、txt文件:

@echo off
echo 删除桌面上的数据文件
forfiles /s /p %USERPROFILE%\Desktop /m *.docx /d -7 /c "cmd /c del @path"
forfiles /s /p %USERPROFILE%\Desktop /m *.xlsx /d -7 /c "cmd /c del @path"
forfiles /s /p %USERPROFILE%\Desktop /m *.txt /d -7 /c "cmd /c del @path"

echo 删除下载目录的数据文件

forfiles /s /p %USERPROFILE%\Downloads /m *.docx /d -7 /c "cmd /c del @path"
forfiles /s /p %USERPROFILE%\Downloads /m *.xlsx /d -7 /c "cmd /c del @path"
forfiles /s /p %USERPROFILE%\Downloads /m *.txt /d -7 /c "cmd /c del @path"

Forfiles语法介绍:

从文件夹或树中选择要进行批处理的文件。

语法

forfiles [/p Path] [/m SearchMask] [/s] [/c Command] [/d[{+ | -}] [{MM/DD/YYYY | DD}]]

参数

/p Path

指定 Path,表明要从哪里开始搜索。默认的文件夹是当前工作目录,该目录通过键入句号 (.) 指定。

/m SearchMask

按照 SearchMask 搜索文件。默认的 SearchMask 是 *.*。

/s

指示 forfiles 在子目录中搜索。

/c Command

在每个文件上运行指定的 Command。带有空格的命令字符串必须用引号括起来。默认的 Command 是 "cmd /c echo @file"。

/d[{+ | -}] [{MM/DD/YYYY DD}]

选择日期大于或等于 (+)(或者小于或等于 (-))指定日期的文件,其中 MM/DD/YYYY 是指定的日期,DD 是当前日期减去 DD 天。如果未指定 + 或 -,则使用 +。DD 的有效范围是 0 - 32768。

/?

在命令提示符下显示帮助。

注释:

Forfiles 最常用于批处理文件中。


Forfiles /s 与 dir /s 类似。


下表列出了可在 /cCommand 命令字符串中使用的变量。

 
变量 描述

@file


文件名


@fname


无扩展名的文件名


@ext


文件扩展名


@path


文件的完整路径


@relpath


文件的相对路径


@isdir


如果文件类型是目录,则计算值为 TRUE,否则值为 FALSE


@fsize


用字节表示的文件大小


@fdate


文件中上次修改的日期戳


@ftime


文件中上次修改的时间戳


使用 forfiles,可以在多个文件上运行命令或将参数传递给多个文件。例如,可以在树中带有 *.txt 扩展名的所有文件上运行 TYPE 命令。或者,可以用文件名“Myinput.txt”作为第一个参数,在 C:/ 驱动器上执行每个批处理文件 (*.bat)。


通过使用 forfiles,可以执行下列任何操作:


使用 /d 按照绝对或相对日期选择文件。


使用诸如 @fsize(文件大小)和 @fdate(文件日期)这样的变量构建文件的存档树。


使用 @isdir 变量区分文件和目录。


通过在命令行中包含特殊字符和使用十六进制代码 0xHH 环绕字符来格式化输出内容。


Forfiles 通过在旨在仅处理单个文件的工具上执行“循环子目录”标记来发挥作用。

示例

要列出驱动器 C: 上的所有批处理文件,请键入:

forfiles /p c:/ /s /m*.bat /c"cmd /c echo @file is a batch file"

要列出驱动器 C: 上的所有目录,请键入:

forfiles /p c:/ /s /m*.* /c"cmd /c if @isdir==true echo @file is a directory"

要列出驱动器 C: 上存在时间多于 100 天的所有文件,请键入:

forfiles /p c:/ /s /m*.* /dt-100 /c"cmd /c echo @file :date >= 100 days"

要列出驱动器 C: 上 1993 年 1 月 1 日以前创建的所有文件,而且对于日期早于 1993 年 1 月 1 日的文件显示“file is quite old!”,请键入:

forfiles /p c:/ /s /m*.* /dt-01011993 /c"cmd /c echo @file is quite old!"

要按列格式列出驱动器 C: 上所有文件的扩展名,请键入:

forfiles /p c:/ /s /m*.* /c "cmd /c echo extension of @file is [email protected]" With:

要列出驱动器 C: 上的所有批处理文件,请键入:

forfiles /p c:/ /s /m *.bat /c "cmd /c echo @file is a batch file"

要列出驱动器 C: 上的所有目录,请键入:

forfiles /p c:/ /s /m *.* /c "cmd /c if @isdir==true echo @file is a directory"

要列出驱动器 C: 上存在时间多于 100 天的所有文件,请键入:

forfiles /p c:/ /s /m *.* /d t-100 /c "cmd /c echo @file :date >= 100 days"

要列出驱动器 C: 上 1993 年 1 月 1 日以前创建的所有文件,而且对于日期早于 1993 年 1 月 1 日的文件显示“file is quite old!”,请键入:

forfiles /p c:/ /s /m *.* /d t-01011993 /c "cmd /c echo @file is quite old!"

要按列格式列出驱动器 C: 上所有文件的扩展名,请键入:

forfiles /p c:/ /s /m*.* /c "cmd /c echo extension of @file is [email protected]"

forfiles的语法介绍是抄别人的,原文链接:https://blog.csdn.net/jamex/article/details/3885935

域控:域控是Windows server 2012

域策略中可以将脚本设置为,启动脚本、关机脚本、登录脚本、注销脚本,前两种是计算机配置,后两种是用户配置,各人根据自己的需求写脚本,我是在域控添加登录脚本,步骤如下:

1.服务器管理器------>工具------>组策略管理------>新建一个组策略对象,链接到你需要分配的OU上

2.选中新建的组策略对象,我的是定期删除数据文件,右键编辑,用户配置------>Windows设置------>脚本(登录/注销)------>双击登录

选择添加

选择浏览

将你的脚本放在这个目录中,选中

选中确定,应用即可

关掉窗口,打开运行,强制刷新组策略,输入gupdate /force

原文地址:https://www.cnblogs.com/nice1163/p/11153882.html

时间: 2024-10-09 05:22:23

forfiles结合域控定期删除文件的相关文章

Python定期删除文件、整理文件夹

1.根据传入的参数,文件所在目录,匹配文件的正则表达式,过期天数进行删除,这些可写在配置文件del_file.conf. del_file3.py #!/usr/bin/env python # encoding: GBK import os import re import sys import time import datetime import logging #reload(sys) #sys.setdefaultencoding('utf-8') logging.basicConfi

定期删除文件

系统长时间的备份会产生大量的过时文件 #!/bin/bash logback_path=/home/rzrk/server/logbackup/ logback_30day_ago=`find -mtime +30` cd   $logback_path echo -e '正在搜索30天以前的文件' sleep 1 find -mtime  +30 while read -p  'Please Enter to Delete files[Y/N]:'  choose do if [ "$choo

Exchange 2007(一)03R2域控升级到2008R2

最近在整理自己的电脑.找到一篇11年写的测试文档,下面是经过修改后的内容. 2011年,朋友所在的公司,一台DC一台Exchange2007都是物理机,没有DHCP和证书(300多个用户).2003R2域控是一台组装机,硬盘快挂了,开机要20多分钟,还一直嘎嘎响.准备了一台08R2辅助域控,转移角色后,08R2升为主域控,删除老域控.以下是测试环境 架构如下: 角色 系统 机器名 IP地址 老DC 2003R2 PEKDC1-DCS-01 192.168.2.30 邮件服务器 2003R2+EX

客户端无法退出AD域控,无法修改计算机名字(服务器上的安全数据没有此工作站信任关系的计算机账户!)

今天早上有一台客户机,昨天使用人修改自己的密码后,发现无法登陆,提示:服务器上的安全数据没有此工作站信任关系的计算机账户!后排查发现,既无法退域,也无法修改DNS后缀,也无法修改计算机名字! 解决办法: 经过多次研究,已经搞定,网上已经有的办法我就不说了,大家或许会发现基本上没有用,我用的办法是:1.在域控上删除这台电脑的计算机名字,同时在dns服务器上删除他的DNS解析记录:2.重新获取IP,并且客户端重新注册DNS:ipconfig /registerdns 3.在AD上重置该用户的密码:4

定期删除IIS日志文件

服务器中由于监控的需要会经常生成很多日志文件,比如IIS日志文件(C:\inetpub\logs\LogFiles),一个稍微有流量的网站,其日志每天可以达到上百兆,这些文件日积月累会严重的占用服务器磁盘空间.有必要对他们进行定期删除.dos批处理程序如下: :: 清理IIS日志文件 :: 备份MySql数据库 @echo off title 清理IIS日志文件 :: IIS日志文件目录 set log_dir="C:\inetpub\logs\LogFiles" :: 保留日志天数

Windows server 2012 角色转移及删除域控方法

本章博文讲述Windows server 2012 如何夺取主域控角色及删除域控方法 .针对不同的运行环境,对操作方法进行了归纳与总结   . 下面分2种情况做介绍  : 一.环境:主域控制器ds01.bicionline.org ,辅域控制器pdc01.bicionline.org  , 两台域控服务器运行正常,相互间可以实现AD复制.目的:主域控服务器把RID.PDC.Domain.Schema.Naming角色及GC功能转移到辅助域控制器,并降级成普通服务器.解决思路:通过图形界面或命令行

C# 系统应用之ListView控件 (三).添加ContextMenuStrip右键菜单打开文件和删除文件功能

在前面讲述过使用TreeView控件和ListView控件显示磁盘目录信息,但仅仅是显示信息是不够的,我们还需要具体的操作.在"个人电脑使用历史痕迹"项目中我还需要添加"打开文件"和"删除文件"两种方法.具体如下: 在第一篇文章"C# 系统应用之TreeView控件 (一).显示树状磁盘文件目录及加载图标"中显示如下: http://blog.csdn.net/eastmount/article/details/1945310

【菜鸟学Linux】Cron Job定期删除Log(日志)文件

以前一直做Windows开发,近期的项目中要求使用Linux.作为小菜鸟一枚,赶紧买了一本经典书<鸟哥的Linux私房菜>学习.最近刚好有一个小任务 - 由于产品产生的Log很多,而且增长很快,所以需要用脚本(Bash scripts)删除过期的Log文件. 使用Linux下的Cron Job可以很好的解决这个问题. 什么是Cron Job? 建立Cron Job需要用到命令crontab,维基百科定义:crontab命令常见于Unix和类Unix的操作系统之中,用于设置周期性被执行的指令.

Azure Automation (2) 定期删除存储账号中的文件

<Windows Azure Platform 系列文章目录> 本文介绍的是国内由世纪互联运维的Azure China. 本文是对笔者之前的文档Azure Backup (1) 将SQL Server 2012虚拟机中数据库备份到Azure Storage进行的补充. 希望笔者先阅读Azure Automation (1) 入门,对Azure Automation有基本的概念认识. 需求: 在之前的文档中Azure Backup (1) 将SQL Server 2012虚拟机中数据库备份到Az