![]() |
Languages »
VBScript »
General
Intermediate
License: The Code Project Open License (CPOL)
Use date & time in batch/log filesBy Peter VerijkeUse date and time in batch/log files |
VBScriptWin2K, WinXP, Win2003, Dev
|
||||||||||
|
Advanced Search Add to IE Search |
|
|
|
||||||||||||||||
Did you ever tried to use date and time in logfiles or batch/command files.
This is not easy without special software.
For me this was a problem because I needed a separate logfile every time when an event happened.
I also needed this to create backup schedules.
The possibilities of batch command is to limited, and different language OS will react different, so it is hard to roll such batch files out in a multi language OS environment.
Te solution is very simpel.
I run a VB script where it is easy to get date time and other parameters.
These values are stored in environment variables which can be used in batch files.
Because these environment variables are only valid in that particular shell, we need to call the batch file within the VB Script.
Copy the following code in a file called RunNow.cmd
'***********************************************
'
' RunNow.vbs
' (c) 2008 Computech.
' Initialy Version 2003.
' 2/2/2008 Extra Functionality
' Written by Peter Verijke
'
'***********************************************
Dim dDay, dLDOM, dLDOY, dLFOW, dLFOM
Dim ArgObj
Dim BatchFile
Dim sCommand
Dim WshShell ' as object
Dim objEnv ' as collection
Dim sGetMyVar ' as string
' Get the Arguments object
Set ArgObj = WScript.Arguments
' Test to make sure there is at least one command line arg - the command
If ArgObj.Count < 1 Then
DisplayHelpMessage
WScript.Quit
End If
BatchFile = ArgObj(0)
Set WshShell = WScript.CreateObject("WScript.Shell")
Set objEnv = WshShell.Environment("PROCESS")
dNow = Now()
dLDOM = DateSerial(Year(dNow),Month(dNow) + 1,0)
dLDOY = DateSerial(Year(dNow) + 1, 1,0)
'Friday of this week
dLFOW = (dNow + (5 - Weekday(dNow, vbMonday)))
'Last Friday of Month
dLFOM = (dLDOM + (5 - Weekday(dLDOM, vbMonday)))
objEnv("Year") = Year(dNow)
objEnv("Month") = Right("0" & Month(dNow), 2)
objEnv("Day") = Right("0" & Day(dNow), 2)
objEnv("Hour") = Right("0" & Hour(dNow), 2)
objEnv("Minute") = Right("0" & Minute(dNow), 2)
objEnv("Second") = Right("0" & Second(dNow), 2)
'Day of Week
objEnv("DOW") = Weekday(dNow, vbMonday)
'Day of Week Name
objEnv("DOWN") = WeekDayName(WeekDay(dNow), 1)
'Week of Month
objEnv("WOM") = -Int(-((WEEKDAY(dNow-DAY(dNow)+1, 2) + DAY(dNow) -1) / 7))
'Last Day of Month
objEnv("LDOM") = Right("0" & Day(dLDOM), 2)
'Last Day of Year
objEnv("LDOY") = Right("0" & Day(dLDOY), 2)
'Last Friday of Week
objEnv("LFOW") = Right("0" & Day(dLFOW), 2)
'Last Friday of Month
objEnv("LFOM") = Right("0" & Day(dLFOM), 2)
sCommand = "%COMSPEC% /C "
WshShell.Run(sCommand + BatchFile)
WScript.Quit
'************************
'
' Display Help Message
'
'************************
Sub DisplayHelpMessage()
Dim sHelpMessage
sHelpMessage = "Usage:" & vbCrLf
sHelpMessage = sHelpMessage & Wscript.FullName & " RunNow <CommandFile|BatchFile>" & vbCrLf
sHelpMessage = sHelpMessage & "Optionally use environment variables in file: %Year% %Month% %Day% %Hour% %Minute% %Second%" & vbCrLf
sHelpMessage = sHelpMessage & " %DOW% %DOWN% %WOM% %LDOM% %LDOY% %LFOW% %LFOM%" & vbCrLf
WScript.Echo sHelpMessage
End Sub
dir > MyLog%Year%%Month%%Day%-%Hour%%Minute%%Second%.log
Instead of running this file directly, run via the VB Script:
RunNow.vbs mydir.cmd
There is also now some extra environment variables like Last Day of Month, Week of Month etc..
These variables can also be used for naming or comparing to take other actions in batch files.
I use it to create for some data Day, Week and Month Backups.
Thats it.
I hope this will be usefull to you.
Peter Verijke
General
News
Question
Answer
Joke
Rant
Admin
|
PermaLink |
Privacy |
Terms of Use
Last Updated: 1 Feb 2008 Editor: |
Copyright 2003 by Peter Verijke Everything else Copyright © CodeProject, 1999-2009 Web21 | Advertise on the Code Project |