
請教批處理命令I(lǐng)F使用有個(gè)實(shí)際需求,每天要下載相關(guān)文件,但在命名時(shí)規(guī)則要調(diào)整為XX+YYMMDD.xlsx(這里的YYMMDD指的是上一個(gè)工作日)。百度了部分資料,腳本如下:rem 計(jì)算指定天數(shù)之前的日期rem 假設(shè)系統(tǒng)日期的格式為yyyy-mm-ddif defined %date:~-3%==周一 (echo num=3 )else echo num=1set DaysAgo=numcall ateToDays %date:~0,4% %date:~5,2% %date:~8,2% PassDaysset /a PassDays-=%DaysAgo%call :DaysToDate %PassDays% DstYear DstMonth DstDayecho %DaysAgo%天的日期是%DstMonth%月%DstDay%日ren XX.xlsx XX%date:~0,4%%DstMonth%%DstDay%.xlsxpausegoto :eof:DateToDays %yy% %mm% %dd% dayssetlocal ENABLEEXTENSIonSset yy=%1&set mm=%2&set dd=%3if 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%%%100set /a z=14-mm,z/=12,y=yy+4800-z,m=mm+12*z-3,j=153*m+2set /a j=j/5+dd+y*365+y/4-y/100+y/400-2472633endlocal&set %4=%j%&goto :EOF:DaysToDate %days% yy mm ddsetlocal ENABLEEXTENSIonSset /a a=%1+2472632,b=4*a+3,b/=146097,c=-b*146097,c/=4,c+=aset /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/=5set /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這里有個(gè)問題,給 DaysAgo賦值的時(shí)候,總是num,而不是if函數(shù)中判斷的num,請教如何將if函數(shù)判斷的num賦值給 DaysAgo盼大神解答,謝謝

