Anyway, I wanted to be able to run a process sometime after midnight that would gather and zip the previous day's files and stash the zipped files in another location for archival. It's pretty easy to calculate the previous day's date if it's in the middle of the month, but what if it's the first of the month, first of the year, and what about leap year, etc., etc. . . ? So I searched around the web a bit and came across a great solution to this issue on Experts Exchange (Get Yesterday date in MS DOS Batch file). Thanks to SteveGTR for this one.
I have modified the original script a bit to suite my needs. Most notably at the end of the script I create two variables, IISDT and AWSDT, to match IIS and Amazon Web Services (S3 and CloudFront) log formats, respectively. I use this in a simple batch file which is executed like, "gather_log_files.bat 1." The number "1" is passed into the script which calculates the date of "1" day before the current date. Of course you could pass any number in there to generate a date x days in the past. It's very slick. NOTE: If you don't specify a number after the batch file "1" is assumed.
So, without further ado, here's the script.
@echo offThe results would look like:
set yyyy=
set $tok=1-3
for /f "tokens=1 delims=.:/-, " %%u in ('date /t') do set $d1=%%u
if "%$d1:~0,1%" GTR "9" set $tok=2-4
for /f "tokens=%$tok% delims=.:/-, " %%u in ('date /t') do (
for /f "skip=1 tokens=2-4 delims=/-,()." %%x in ('echo.^|date') do (
set %%x=%%u
set %%y=%%v
set %%z=%%w
set $d1=
set $tok=))
if "%yyyy%"=="" set yyyy=%yy%
if /I %yyyy% LSS 100 set /A yyyy=2000 + 1%yyyy% - 100
set CurDate=%mm%/%dd%/%yyyy%
set dayCnt=%1
if "%dayCnt%"=="" set dayCnt=1
REM Substract your days here
set /A dd=1%dd% - 100 - %dayCnt%
set /A mm=1%mm% - 100
:CHKDAY
if /I %dd% GTR 0 goto DONE
set /A mm=%mm% - 1
if /I %mm% GTR 0 goto ADJUSTDAY
set /A mm=12
set /A yyyy=%yyyy% - 1
:ADJUSTDAY
if %mm%==1 goto SET31
if %mm%==2 goto LEAPCHK
if %mm%==3 goto SET31
if %mm%==4 goto SET30
if %mm%==5 goto SET31
if %mm%==6 goto SET30
if %mm%==7 goto SET31
if %mm%==8 goto SET31
if %mm%==9 goto SET30
if %mm%==10 goto SET31
if %mm%==11 goto SET30
REM ** Month 12 falls through
:SET31
set /A dd=31 + %dd%
goto CHKDAY
:SET30
set /A dd=30 + %dd%
goto CHKDAY
:LEAPCHK
set /A tt=%yyyy% %% 4
if not %tt%==0 goto SET28
set /A tt=%yyyy% %% 100
if not %tt%==0 goto SET29
set /A tt=%yyyy% %% 400
if %tt%==0 goto SET29
:SET28
set /A dd=28 + %dd%
goto CHKDAY
:SET29
set /A dd=29 + %dd%
goto CHKDAY
:DONE
if /I %mm% LSS 10 set mm=0%mm%
if /I %dd% LSS 10 set dd=0%dd%
REM Set IIS and AWS date variables
set IISDT=%yyyy:~2,2%%mm%%dd%
set AWSDT=%yyyy%-%mm%-%dd%
IIS Date: 20100727
AWS Date: 2010-07-27
Thanks man. Your script is very useful.
ReplyDeleteThis script is great. I've been looking around for dos batch yesterday for a while. This rocks!
ReplyDeleteThis is the best way I've found to get yesterday's date in a dos or windows command line or batch file. Great work!!
ReplyDeletethis is great for echoing date from day before in windows batch files.
ReplyDeleteHey i would like get 2 different variables like y1date (which stores 1 day before date) and y2date (which stores 1 day before date). Can u please email me the solution to mayureshmulye@gmail.com
ReplyDeleteThanks in advance.
Great! Thanks!!!!!
ReplyDeleteDoes not work on leap day.. bad.
ReplyDeleteGreat script¡¡¡ works perfect. Thanks
ReplyDeleteIt worked fine for me on leap day this year. I have several scripts that run daily using this and they all worked fine.
ReplyDeleteAgreed, this is a great script. It's as complex as it needs to be! :)
ReplyDeleteThank You, it helps for me too!! :D
ReplyDeleteThis is indeed good, I use it to move the previous days log file to a folder. The only problem is, it doesn't work for moving Friday's log file on Monday. Any way it could be modified to get the previous business days date.
ReplyDeleteSaved me a good deal of time. Thanks man!
ReplyDeleteKudos, much appreciated!
ReplyDeleteAny idea how this can be amended if I want to find files and copy to folders with this date format:
ReplyDeleteDD-MMM-YYYY, e.g
21-NOV-2012
This is perfect!
ReplyDeleteNow someone has to do the opposite so we can get the date in the future :)
Thanks so much mate!!
ReplyDeleteThanks for providing this, it definitely helped with my batch file problem!
ReplyDeleteHow did they write first operating system if this script only gets you previous day date :-O
ReplyDeleteThis is great. Thanks for sharing this piece of code. It helped a lot in my project.
ReplyDeleteBless you! Exactly what I needed.
ReplyDeleteGreat script, works perfectly many thanks.
ReplyDeleteYou made my day! Finally got what I have been looking for. Thank you very very much.
ReplyDeleteThank you. I needed.
ReplyDeleteI'm pretty new to .bat files. I understand that this is supposed to retrieve the previous day's date, but how can I check it to make sure? As soon as I run the .bat file, it closes. Please be gentle lol.
ReplyDeleteYou could add any (or all) of the following to the bottom of the batch file, including "pause." That way it will display the value(s) on screen, then pause the execution of the file.
ReplyDeleteecho %IISDT%
echo %AWSDT%
pause
You are awesome! That is a super simple fix! Thanks*1,000,000!
DeleteYou're welcome! Glad to help.
ReplyDeleteUnlike all other scripts that are either uncomplete, confusing, show-off or incorrect, this one really gets to the point and works. many thanks!
ReplyDeleteWow does what it says, thanks again
ReplyDeletethis is great. if you want it to go back to last working day (ie 3 days on Monday) add this at the top
ReplyDeletefor /f "skip=1 tokens=1" %%a in ('wmic path win32_localtime get dayofweek ^| findstr /b /r "."') do set /a dow=%%a +1
for /f "tokens=%dow%" %%a in ("Sunday Monday Tuesday Wednesday Thursday Friday Saturday") do set day=%%a
echo Today is %dow% which is %day%
echo if it's Monday we go back 3 days for the filename (friday), otherwise it's just one day
set dayCnt=1
if "%dow%"=="2" set dayCnt=3
echo going back %dayCnt% days
Great script ...very useful
ReplyDeletethank every much. you script is useful
ReplyDeletesuper usefull, thanks
ReplyDeleteThanks. This is exactly what I was looking for.
ReplyDelete