标题: [文件操作] 批处理怎样定期删除ftp上的旧备份文件? [打印本页]
作者: qwertl 时间: 2010-2-1 23:42 标题: 批处理怎样定期删除ftp上的旧备份文件?
ftp> dir * 1.txt生成1.txt 格式如下:
-rw-rw-rw- 1 user group 173486 Jan 18 20:10 5512_17Dgdaj-xxwj_20100118_1800.bak.zip
-rw-rw-rw- 1 user group 173464 Jan 19 20:10 5512_17Dgdaj-xxwj_20100119_1800.bak.zip
-rw-rw-rw- 1 user group 173487 Jan 20 20:10 5512_17Dgdaj-xxwj_20100120_1800.bak.zip
-rw-rw-rw- 1 user group 173466 Jan 21 20:10 5512_17Dgdaj-xxwj_20100121_1800.bak.zip
-rw-rw-rw- 1 user group 173486 Jan 22 20:10 5512_17Dgdaj-xxwj_20100122_1800.bak.zip
-rw-rw-rw- 1 user group 173467 Jan 23 20:10 5512_17Dgdaj-xxwj_20100123_1800.bak.zip
-rw-rw-rw- 1 user group 173487 Jan 24 20:10 5512_17Dgdaj-xxwj_20100124_1800.bak.zip
-rw-rw-rw- 1 user group 173462 Jan 25 20:10 5512_17Dgdaj-xxwj_20100125_1800.bak.zip
-rw-rw-rw- 1 user group 173482 Jan 26 20:10 5512_17Dgdaj-xxwj_20100126_1800.bak.zip
-rw-rw-rw- 1 user group 173467 Jan 27 20:10 5512_17Dgdaj-xxwj_20100127_1800.bak.zip
-rw-rw-rw- 1 user group 173483 Jan 28 20:10 5512_17Dgdaj-xxwj_20100128_1800.bak.zip
-rw-rw-rw- 1 user group 173454 Jan 29 20:10 5512_17Dgdaj-xxwj_20100129_1800.bak.zip
-rw-rw-rw- 1 user group 173484 Jan 30 20:10 5512_17Dgdaj-xxwj_20100130_1800.bak.zip
-rw-rw-rw- 1 user group 173463 Jan 31 20:10 5512_17Dgdaj-xxwj_20100131_1800.bak.zip
-rw-rw-rw- 1 user group 173481 Feb 1 20:10 5512_17Dgdaj-xxwj_20100201_1800.bak.zip
要怎样将文件名5512_17Dgdaj-xxwj_20100201_1800.bak.zip中包含的日期(即‘_’分隔的第三段与FTP客户端本机日期对比,如果小于15天前日期的文件名就将FTP上的文件执行删除??
作者: vsbat 时间: 2010-2-2 00:00
涉及到月份日期 相减 很麻烦的
作者: qwertl 时间: 2010-2-2 00:14
共享一下(根据batcher提供类似的代码修改):- rem 格式:
- rem -rw-rw-rw- 1 user group 1004346458 Jan 3 18:43 2011_pwdll_20100102_2255.rar
- @echo off
- rem 指定FTP用户名
- set ftpUser=aaa
- rem 指定FTP密码
- set ftppass=aaa
- rem 指定FTP服务器地址
- set ftpIP=11.11.22.22
- rem 指定待删除的文件位于FTP服务器的什么位置
- set ftpFolder=/dat1
- rem 指定删除几天前的文件
- set DaysAgo=15
- set ftpDir=%temp%\TempDir.txt
- set ftpDel=%temp%\Tempdel.txt
- rem 假设本机日期格式为yyyy-mm-dd
- set FileY=%date:~0,4%
- call :DateToDays %date:~0,4% %date:~5,2% %date:~8,2% PassDays
- set /a PassDays-=DaysAgo
- call :DaysToDate %PassDays% DstYear DstMonth DstDay
- >"%ftpDir%" echo.%ftpUser%
- >>"%ftpDir%" echo.%ftpPass%
- >>"%ftpDir%" echo bin
- >>"%ftpDir%" echo cd "%ftpFolder%"
- >>"%ftpDir%" echo dir * "%temp%\FileList.txt"
- >>"%ftpDir%" echo bye
- start ftp -v -i -s:"%ftpDir%" %ftpIP%
- ping 127.1 -n 12
- >"%ftpDel%" echo.%ftpUser%
- >>"%ftpDel%" echo.%ftpPass%
- >>"%ftpDel%" echo bin
- >>"%ftpDel%" echo cd "%ftpFolder%"
- (for /f "usebackq skip=2 tokens=1-12 delims=_ " %%a in ("%temp%\Filelist.txt") do (
- if "%%k" leq "%DstYear%%DstMonth%%DstDay%" (
- echo del "%%i_%%j_%%k_%%l"
- )
- endlocal
- ))>>"%ftpDel%"
- >>"%ftpDel%" echo bye
- ping -n 5 127.1 >nul
- rem -rw-rw-rw- 1 user group 1004346458 Jan 3 18:43 2011_ptas_20100102_2255.rar
- rem start ftp -v -i -s:"%ftpDel%" %ftpIP%
- ping -n 6 127.1 >nul
- rem sdelete -p 1 "%ftpDel%"
- rem sdelete -p 1 "%ftpDir%"
- rem sdelete -p 1 "%temp%\Filelist.txt"
- 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
复制代码
作者: tianya520feng 时间: 2010-2-2 14:04
额,按照楼主的思路做了一下。整体思路是这样的:先模拟环境,建一些文件,然后建一个批处理来操作。
先建一个1.txt 文件,内容即为楼主所列的
-rw-rw-rw- 1 user group 173486 Jan 18 20:10 5512_17Dgdaj-xxwj_20100118_1800.bak.zip
-rw-rw-rw- 1 user group 173464 Jan 19 20:10 5512_17Dgdaj-xxwj_20100119_1800.bak.zip
-rw-rw-rw- 1 user group 173487 Jan 20 20:10 5512_17Dgdaj-xxwj_20100120_1800.bak.zip
-rw-rw-rw- 1 user group 173466 Jan 21 20:10 5512_17Dgdaj-xxwj_20100121_1800.bak.zip
-rw-rw-rw- 1 user group 173486 Jan 22 20:10 5512_17Dgdaj-xxwj_20100122_1800.bak.zip
-rw-rw-rw- 1 user group 173467 Jan 23 20:10 5512_17Dgdaj-xxwj_20100123_1800.bak.zip
-rw-rw-rw- 1 user group 173487 Jan 24 20:10 5512_17Dgdaj-xxwj_20100124_1800.bak.zip
-rw-rw-rw- 1 user group 173462 Jan 25 20:10 5512_17Dgdaj-xxwj_20100125_1800.bak.zip
-rw-rw-rw- 1 user group 173482 Jan 26 20:10 5512_17Dgdaj-xxwj_20100126_1800.bak.zip
-rw-rw-rw- 1 user group 173467 Jan 27 20:10 5512_17Dgdaj-xxwj_20100127_1800.bak.zip
-rw-rw-rw- 1 user group 173483 Jan 28 20:10 5512_17Dgdaj-xxwj_20100128_1800.bak.zip
-rw-rw-rw- 1 user group 173454 Jan 29 20:10 5512_17Dgdaj-xxwj_20100129_1800.bak.zip
-rw-rw-rw- 1 user group 173484 Jan 30 20:10 5512_17Dgdaj-xxwj_20100130_1800.bak.zip
-rw-rw-rw- 1 user group 173463 Jan 31 20:10 5512_17Dgdaj-xxwj_20100131_1800.bak.zip
-rw-rw-rw- 1 user group 173481 Feb 1 20:10 5512_17Dgdaj-xxwj_20100201_1800.bak.zip
然后在 1.txt 同目录下建一批处理文件,内容为:- @echo off&setlocal EnableDelayedExpansion
- for /f "tokens=9" %%i in (1.txt) do (echo %%i>>b.txt)
- ::选取文件名列表
- for /f %%i in (b.txt) do (cd.>%%i)
- ::根据上面的文件名列表批量新建文件,作为演示
- del b.txt
- echo 新建演示文件成功
- dir *.zip
- ::删除临时文件b.txt
- for /f "tokens=1-3 delims=-/ " %%a in ('date /t') do set/a date1=%%a*365+%%b*30+%%c
- ::2010*365+02*30+02
- ::获取当前系统时间的数字格式
- ::echo 当前时间值为%date1%
- set/p date2=请设定要删除几天前的记录:
- set/a date3=%date1%-%date2%
- ::echo 之后时间值为%date3%
- for /r %%i in (*.zip) do (
- ::echo %%~nxi
- set var=%%~nxi
- ::echo !var!
- set var1=!var!
- call, set/a var2=%%var1:~18,8%%
- ::echo !var2!
- call, set/a var3=%%var2:~0,4%%*365+%%var2:~4,2%%*30+%%var2:~-2%%
- ::echo !var3!
- if !var3! leq %date3% (del %%i) else echo.
- )
- echo 处理后文件列表:
- dir *.zip
- pause
复制代码
以上代码均做了详细的注释,注一下,我电脑上的日期格式为:复制代码
如果日期格式不同,请自行修改。
运行结果如下(我选择删除3天前记录):- 新建演示文件成功
- 驱动器 D 中的卷是 Windows 2003
- 卷的序列号是 6C8A-606C
-
- D:\我的文档\桌面\新建文件夹 的目录
-
- 2010-02-02 14:00 0 5512_17Dgdaj-xxwj_20100118_1800.bak.zip
- 2010-02-02 14:00 0 5512_17Dgdaj-xxwj_20100119_1800.bak.zip
- 2010-02-02 14:00 0 5512_17Dgdaj-xxwj_20100120_1800.bak.zip
- 2010-02-02 14:00 0 5512_17Dgdaj-xxwj_20100121_1800.bak.zip
- 2010-02-02 14:00 0 5512_17Dgdaj-xxwj_20100122_1800.bak.zip
- 2010-02-02 14:00 0 5512_17Dgdaj-xxwj_20100123_1800.bak.zip
- 2010-02-02 14:00 0 5512_17Dgdaj-xxwj_20100124_1800.bak.zip
- 2010-02-02 14:00 0 5512_17Dgdaj-xxwj_20100125_1800.bak.zip
- 2010-02-02 14:00 0 5512_17Dgdaj-xxwj_20100126_1800.bak.zip
- 2010-02-02 14:00 0 5512_17Dgdaj-xxwj_20100127_1800.bak.zip
- 2010-02-02 14:00 0 5512_17Dgdaj-xxwj_20100128_1800.bak.zip
- 2010-02-02 14:00 0 5512_17Dgdaj-xxwj_20100129_1800.bak.zip
- 2010-02-02 14:00 0 5512_17Dgdaj-xxwj_20100130_1800.bak.zip
- 2010-02-02 14:00 0 5512_17Dgdaj-xxwj_20100131_1800.bak.zip
- 2010-02-02 14:00 0 5512_17Dgdaj-xxwj_20100201_1800.bak.zip
- 15 个文件 0 字节
- 0 个目录 14,049,058,816 可用字节
- 请设定要删除几天前的记录:3
-
-
-
- 处理后文件列表:
- 驱动器 D 中的卷是 Windows 2003
- 卷的序列号是 6C8A-606C
-
- D:\我的文档\桌面\新建文件夹 的目录
-
- 2010-02-02 14:00 0 5512_17Dgdaj-xxwj_20100130_1800.bak.zip
- 2010-02-02 14:00 0 5512_17Dgdaj-xxwj_20100131_1800.bak.zip
- 2010-02-02 14:00 0 5512_17Dgdaj-xxwj_20100201_1800.bak.zip
- 3 个文件 0 字节
- 0 个目录 14,049,058,816 可用字节
- 请按任意键继续. . .
复制代码
我也是上个星期才接触批处理,这代码感觉写得很臃肿,比如用到var1,var2,var3什么的,可是我不知道怎么去简化代码,请大家帮帮忙,教教我应该如何简化,谢谢了!
注明一下:该方法存在误差,误差天数应该在1天,也就是说,你删除50天前的数据,可能实际上只保留了49天的数据,因为我的天数是按30天来算的,没细想了,我想即使有误差,这点误差也影响不大,呵呵,因为我也经常管理公司数据库的备份 ^_^
[ 本帖最后由 tianya520feng 于 2010-2-2 14:08 编辑 ]
作者: sysplay 时间: 2010-2-2 19:28
我觉得可以考虑使用forfiles命令,这个命令在Win2003中,xp中不知道有没有。-
- @echo off
- forfiles /D -15 /C "cmd /c del @file"
- pause
复制代码
forfiles是通过文件的上一次修改时间来删除文件的。
[ 本帖最后由 sysplay 于 2010-2-2 19:30 编辑 ]
作者: Batcher 时间: 2010-2-2 20:51 标题: 回复 5楼 的帖子
XP默认没有自带forfiles命令,forfiles适合删除本地文件,要删除FTP上的文件有难度吧?
欢迎光临 批处理之家 (http://bathome.net./) |
Powered by Discuz! 7.2 |