登录  
 加关注
查看详情
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

糟老頭的地盤

老頭的地盤听老頭的

 
 
 

日志

 
 

批量删除指定子文件夹的DOS命令  

2010-05-30 21:48:52|  分类: study |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |
111111111111111111111111111111111111111111111111111111
在服务器建了个批处理文件定期备份论坛的数据库,保存到 G:\论坛数据库 ,以 数据库备份_20091024 这种格式按日期备份,每5天备份一次

echo off

net stop mysql

set fromdir=G:\Program Files\mysql\data\bccn
set todir=G:\论坛数据库\
set mydir=%todir%mysql_data_%date:~0,4%%date:~5,2%%date:~8,2%
md %mydir%
xcopy %fromdir%\* %mydir% /e

net start mysql

G:\Program Files\mysql\data\bccn 和 G:\论坛数据库\ 分别为备份的源路径和目标路径。
代码中的路径只是示例

2222222222222222222222222222222222222222
@echo off 
title 编程论坛批量删除备份数据库DOS程序                      By:不说也罢 
color 37 

:First 
cls 
echo. 
echo         欢迎使用编程论坛批量删除备份数据库DOS程序 
echo. 
echo                    制作:不说也罢 
echo. 
echo. 
echo  本程序是应编程论坛管理员“静夜思”要求所特别制作,请勿删除作者名字。 
echo. 
echo  目录规则如从 数据库备份_19990101 到 数据库备份_29991231 之间的所有循环目录。 
echo  注意:年份和日期都是四位数字。 
echo. 
goto Date 




:Date 
echo. 
set /p m=请输入四位数的年(如2009)  : 
echo. 
set /p d1=请输入起始日期(如0101)   : 
set /p d2=请输入终止日期(如1231)   : 
echo. 
echo 继续操作将 删除 当前目录下从 数据库备份_%m%%d1% 到 数据库备份_%m%%d2% 之间的所有目录。 
echo. 
set /p go=你确认继续下一步操作吗?(Y/N): 
if %go%==y goto Do else goto Begin 
if %go%==Y goto Do else goto Begin 
goto Begin 

:Begin 
echo. 
set /p go=您要继续执行批量删除操作吗?(Y/N): 
if %go%==y goto Date else goto Begin 
if %go%==Y goto Date else else goto Begin 
exit 

:Do 
echo. 
echo 正在执行 删除 操作,请稍后... 
  for /l %%i in (%d1%,1,%d2%) do if %%i LSS 1000 (rd 数据库备份_%m%%j%0%%i /s /q) else rd 数据库备份_%m%%%i /s /q 
echo. 
echo 删除目录 操作执行完毕,请检查执行效果! 
echo. 
goto Begin

请将上述代码存为.bat文件,放在“G:\论坛数据库”目录下,运行即可.对于只读文件夹能否删除,我没有测试。呵呵。

33333333333333333333333333333333333333333333333333
:: cosdos 2009/10/25
:: --- 以Windows当前系统日期为基础。
:: --- 例当前系统日期:2009/10/25,则删除
:: --- 所有以“数据库备份_”开头,后缀日期
:: --- 小于等于“20090925”的所有文件加。

@Echo off
Setlocal EnableDelayedExpansion
Title 删除当前目录中,上个月的“数据库备份_”文件夹
:: cosdos 2009/10/25
Call :main
Pause
Exit

:LastMonth
    Set /a yyyy=%1+10000
    Set /a mm=%2+100
    Set /a dd=%3+100
    If "%2" == "01"  (
        Set mm=112 & Goto year
    ) else (
        Set /a mm-=1 & Set lastmonthday=%yyyy:~1,4%!mm:~1,2!%dd:~1,2%
    )
    Exit /b
    :year
    Set /a yyyy-=1
    Set lastmonthday=%yyyy:~1,4%%mm:~1,2%%dd:~1,2%
    Exit /b
    
:main
    Set myfolder=数据库备份_
    Set yyyy=%date:~0,4%
    Set mm=%date:~5,2%
    Set dd=%date:~8,2%
    Call:LastMonth %yyyy% %mm% %dd%
    Echo.
    Echo 删除当前目录中,“%myfolder%%lastmonthday%”之前的文件夹
    For /d %%i in (数据库备份_*) do (
        Set folderdate=%%i&&if /i !folderdate:~-8! lEQ %lastmonthday% rd /s /q %%i
    )
    Exit /b

44444444444444444444444444444444444444444444444444444444444
@echo off 
::演示:删除指定路径下指定天数之前(以文件的最后修改日期为准)的文件。 
::如果演示结果无误,把del前面的echo去掉,即可实现真正删除。 
::本例调用了临时VBS代码进行日期计算 
::本例为兼容不同的日期格式,调用reg命令(XP系统自带)统一设置日期格式, 
::处理完毕之后再把日期格式恢复成原来的状态。 

rem 指定待删除文件的存放路径 
set SrcDir=C:\Test\BatHome 
rem 指定天数 
set DaysAgo=1 
for /f "skip=2 delims=" %%a in ('reg query "HKEY_CURRENT_USER\Control Panel\International" /v sShortDate') do ( 
  set "RegDateOld=%%a" 

set RegDateOld=%RegDateOld:~-8% 
reg add "HKEY_CURRENT_USER\Control Panel\International" /v sShortDate /t REG_SZ /d yyyy-M-d /f>nul 
>"%temp%\DstDate.vbs" echo LastDate=date()-%DaysAgo% 
>>"%temp%\DstDate.vbs" echo FmtDate=right(year(LastDate),4) ^& right("0" ^& month(LastDate),2) ^& right("0" ^& day(LastDate),2) 
>>"%temp%\DstDate.vbs" echo wscript.echo FmtDate 
for /f %%a in ('cscript /nologo "%temp%\DstDate.vbs"') do ( 
  set "DstDate=%%a" 

set DstDate=%DstDate:~0,4%-%DstDate:~4,2%-%DstDate:~6,2% 
for /r "%SrcDir%" %%a in (*.*) do ( 
  if "%%~ta" leq "%DstDate%" ( 
    if exist "%%a" ( 
      echo del /f /q "%%a" 
    ) 
  ) 

reg add "HKEY_CURRENT_USER\Control Panel\International" /v sShortDate /t REG_SZ /d %RegDateOld% /f>nul 
pause 
【方案二】删除指定路径下指定天数之前(以文件的最后修改日期为准)的文件:BAT + REG + Ritchie Lawrence 日期函数 
复制内容到剪贴板代码: 
@echo off 
::演示:删除指定路径下指定天数之前(以文件的最后修改日期为准)的文件。 
::如果演示结果无误,把del前面的echo去掉,即可实现真正删除。 
::本例调用了 Ritchie Lawrence 的日期函数进行日期计算 
::日期转换的核心算法请参考http://bbs.bathome.cn/thread-3056-1-1.html 
::本例为兼容不同的日期格式,调用reg命令(XP系统自带)统一设置日期格式, 
::处理完毕之后再把日期格式恢复成原来的状态。 

rem 指定待删除文件的存放路径 
set SrcDir=C:\Test\BatHome 
rem 指定天数 
set DaysAgo=1 
for /f "skip=2 delims=" %%a in ('reg query "HKEY_CURRENT_USER\Control Panel\International" /v sShortDate') do ( 
  set "RegDateOld=%%a" 

set RegDateOld=%RegDateOld:~-8% 
reg add "HKEY_CURRENT_USER\Control Panel\International" /v sShortDate /t REG_SZ /d yyyy-M-d /f>nul 
call :DateToDays %date:~0,4% %date:~5,2% %date:~8,2% PassDays 
reg add "HKEY_CURRENT_USER\Control Panel\International" /v sShortDate /t REG_SZ /d %RegDateOld% /f>nul 
set /a PassDays-=%DaysAgo% 
call :DaysToDate %PassDays% DstYear DstMonth DstDay 
set DstDate=%DstYear%-%DstMonth%-%DstDay% 
for /r "%SrcDir%" %%a in (*.*) do ( 
  if "%%~ta" leq "%DstDate%" ( 
    if exist "%%a" ( 
      echo del /f /q "%%a" 
    ) 
  ) 

reg add "HKEY_CURRENT_USER\Control Panel\International" /v sShortDate /t REG_SZ /d %RegDateOld% /f>nul 
pause 
goto :eof 

:DateToDays %yy% %mm% %dd% days 
setlocal ENABLEEXTENSIONS 
set yy=%1&set mm=%2&set dd=%3 
if 1%yy% LSS 200 if 1%yy% LSS 170 (set yy=20%yy%) else (set yy=19%yy%) 
set /a dd=100%dd%%%100,mm=100%mm%%%100 
set /a z=14-mm,z/=12,y=yy+4800-z,m=mm+12*z-3,j=153*m+2 
set /a j=j/5+dd+y*365+y/4-y/100+y/400-2472633 
endlocal&set %4=%j%&goto :EOF 

:DaysToDate %days% yy mm dd 
setlocal ENABLEEXTENSIONS 
set /a a=%1+2472632,b=4*a+3,b/=146097,c=-b*146097,c/=4,c+=a 
set /a d=4*c+3,d/=1461,e=-1461*d,e/=4,e+=c,m=5*e+2,m/=153,dd=153*m+2,dd/=5 
set /a dd=-dd+e+1,mm=-m/10,mm*=12,mm+=m+3,yy=b*100+d-4800+m/10 
(if %mm% LSS 10 set mm=0%mm%)&(if %dd% LSS 10 set dd=0%dd%) 
endlocal&set %2=%yy%&set %3=%mm%&set %4=%dd%&goto :EOF 
【方案三】删除指定路径下指定天数之前(以文件的最后修改日期为准)的文件:BAT + VBS 
复制内容到剪贴板代码: 
@echo off 
::演示:删除指定路径下指定天数之前(以文件的最后修改日期为准)的文件。 
::如果演示结果无误,把del前面的echo去掉,即可实现真正删除。 
::本例调用了临时VBS代码进行日期计算,并统一设置系统日期格式,处理完毕 
::之后再把日期格式恢复成原来的状态。摆脱了对reg命令(XP系统自带)的依赖。 

rem 指定待删除文件的存放路径 
set SrcDir=C:\Test\BatHome 
rem 指定天数 
set DaysAgo=1 
>"%temp%\BackupDate.vbs" echo Set WshShell = WScript.CreateObject("WScript.Shell") 
>>"%temp%\BackupDate.vbs" echo WScript.Echo WshShell.RegRead ("HKEY_CURRENT_USER\Control Panel\International\sShortDate") 
for /f %%a in ('cscript /nologo "%temp%\BackupDate.vbs"') do ( 
  set "RegDateOld=%%a" 

>"%temp%\UnifyDate.vbs" echo Set WshShell = WScript.CreateObject("WScript.Shell") 
>>"%temp%\UnifyDate.vbs" echo WshShell.RegWrite "HKEY_CURRENT_USER\Control Panel\International\sShortDate", "yyyy-M-d", "REG_SZ" 
cscript /nologo "%temp%\UnifyDate.vbs" 
>"%temp%\DstDate.vbs" echo LastDate=date()-%DaysAgo% 
>>"%temp%\DstDate.vbs" echo FmtDate=right(year(LastDate),4) ^& right("0" ^& month(LastDate),2) ^& right("0" ^& day(LastDate),2) 
>>"%temp%\DstDate.vbs" echo wscript.echo FmtDate 
for /f %%a in ('cscript /nologo "%temp%\DstDate.vbs"') do ( 
  set "DstDate=%%a" 

set DstDate=%DstDate:~0,4%-%DstDate:~4,2%-%DstDate:~6,2% 
for /r "%SrcDir%" %%a in (*.*) do ( 
  if "%%~ta" leq "%DstDate%" ( 
    if exist "%%a" ( 
      echo del /f /q "%%a" 
    ) 
  ) 

>"%temp%\RecoverDate.vbs" echo Set WshShell = WScript.CreateObject("WScript.Shell") 
>>"%temp%\RecoverDate.vbs" echo WshShell.RegWrite "HKEY_CURRENT_USER\Control Panel\International\sShortDate", "%RegDateOld%", "REG_SZ" 
cscript /nologo "%temp%\RecoverDate.vbs" 
pause 
【方案四】删除指定路径下指定天数之前(以文件的创建日期为准)的文件:BAT + REG + Ritchie Lawrence 日期函数 
复制内容到剪贴板代码: 
@echo off 
::演示:删除指定路径下指定天数之前(以文件的创建日期为准)的文件。 
::如果演示结果无误,把del前面的echo去掉,即可实现真正删除。 
::本例调用了 Ritchie Lawrence 的日期函数进行日期计算 
::日期转换的核心算法请参考http://bbs.bathome.cn/thread-3056-1-1.html 
::本例为兼容不同的日期格式,调用reg命令(XP系统自带)统一设置日期格式, 
::处理完毕之后再把日期格式恢复成原来的状态。 

rem 指定待删除文件的存放路径 
set SrcDir=C:\Test\BatHome 
rem 指定天数 
set DaysAgo=1 
for /f "skip=2 delims=" %%a in ('reg query "HKEY_CURRENT_USER\Control Panel\International" /v sShortDate') do ( 
  set "RegDateOld=%%a" 

set RegDateOld=%RegDateOld:~-8% 
reg add "HKEY_CURRENT_USER\Control Panel\International" /v sShortDate /t REG_SZ /d yyyy-M-d /f>nul 
call :DateToDays %date:~0,4% %date:~5,2% %date:~8,2% PassDays 
reg add "HKEY_CURRENT_USER\Control Panel\International" /v sShortDate /t REG_SZ /d %RegDateOld% /f>nul 
set /a PassDays-=%DaysAgo% 
call :DaysToDate %PassDays% DstYear DstMonth DstDay 
set DstDate=%DstYear%-%DstMonth%-%DstDay% 

for /f "delims=/" %%a in ('dir /s /b /a-d "%SrcDir%"') do ( 
  call :CompareTime "%%a" 

reg add "HKEY_CURRENT_USER\Control Panel\International" /v sShortDate /t REG_SZ /d %RegDateOld% /f>nul 
pause 
goto :eof 

:DateToDays %yy% %mm% %dd% days 
setlocal ENABLEEXTENSIONS 
set yy=%1&set mm=%2&set dd=%3 
if 1%yy% LSS 200 if 1%yy% LSS 170 (set yy=20%yy%) else (set yy=19%yy%) 
set /a dd=100%dd%%%100,mm=100%mm%%%100 
set /a z=14-mm,z/=12,y=yy+4800-z,m=mm+12*z-3,j=153*m+2 
set /a j=j/5+dd+y*365+y/4-y/100+y/400-2472633 
endlocal&set %4=%j%&goto :EOF 

:DaysToDate %days% yy mm dd 
setlocal ENABLEEXTENSIONS 
set /a a=%1+2472632,b=4*a+3,b/=146097,c=-b*146097,c/=4,c+=a 
set /a d=4*c+3,d/=1461,e=-1461*d,e/=4,e+=c,m=5*e+2,m/=153,dd=153*m+2,dd/=5 
set /a dd=-dd+e+1,mm=-m/10,mm*=12,mm+=m+3,yy=b*100+d-4800+m/10 
(if %mm% LSS 10 set mm=0%mm%)&(if %dd% LSS 10 set dd=0%dd%) 
endlocal&set %2=%yy%&set %3=%mm%&set %4=%dd%&goto :EOF 

:CompareTime 
for /f "skip=5 tokens=1-2 delims= " %%h in ('dir /a-d /tc %1') do ( 
  if "%%h" leq "%DstDate%" ( 
    if exist %1 ( 
      echo del /a /f /q %1 
    ) 
  ) 
  goto :eof 

【方案五】删除指定路径下指定天数之前(以文件的修改日期为准)的文件:forfiles 
复制内容到剪贴板代码: 
@echo off 
::演示:删除指定路径下指定天数之前(以文件的最后修改日期为准)的文件。 
::如果演示结果无误,把del前面的echo去掉,即可实现真正删除。 
::本例需要Win2003/Vista/Win7系统自带的forfiles命令的支持 

rem 指定待删除文件的存放路径 
set SrcDir=C:\Test\BatHome 
rem 指定天数 
set DaysAgo=1 

forfiles /p %SrcDir% /s /m *.* /d -%DaysAgo% /c "cmd /c echo del /f /q /a @path" 
pause 



------------------------------------------------------------------
  评论这张
 
阅读(4400)| 评论(0)

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2018