|  | 
 
 发表于 2016/11/8 15:19
|
显示全部楼层
|阅读模式
|  Google Chrome 45.0.2454.101|  Windows 7 
 
| VBS显示当前标准时间,例如:执行下面的代码则显示:2013-05-11 19:10:11 
 Option Explicit
 
 Dim blnDate, blnTime
 
 Dim dtmDate
 
 Dim intDay, intFormat, intHour, intMin, intMonth, intSec, intUTC, intValid, intYear
 
 Dim strISO
 
 With WScript.Arguments
 
 ' Check command line arguments
 
 If .Unnamed.Count = 0 Then dtmDate = Now
 
 If .Unnamed.Count > 0 Then dtmDate = .Unnamed(0)
 
 If .Unnamed.Count > 1 Then dtmDate = dtmDate & " " & .Unnamed(1)
 
 If .Unnamed.Count > 2 Then dtmDate = dtmDate & " " & .Unnamed(2)
 
 If .Unnamed.Count > 3 Then Syntax
 
 On Error Resume Next
 
 dtmDate = CDate( dtmDate )
 
 If Err Then
 
 On Error Goto 0
 
 Syntax
 
 End If
 
 On Error Goto 0
 
 If Not IsDate( dtmDate ) Then Syntax
 
 intValid = 0
 
 blnDate = True
 
 blnTime = True
 
 If .Named.Exists( "D" ) Then
 
 blnDate = True
 
 blnTime = False
 
 intValid = intValid + 1
 
 End If
 
 If .Named.Exists( "T" ) Then
 
 blnDate = False
 
 blnTime = True
 
 intValid = intValid + 1
 
 End If
 
 If intValid <> .Named.Count Then Syntax
 
 If intValid > 1 Then Syntax
 
 End With
 
 ' Format the output string
 
 intYear = DatePartLZ( "yyyy", dtmDate )
 
 intMonth = DatePartLZ( "m", dtmDate )
 
 intDay  = DatePartLZ( "d", dtmDate )
 
 intHour = DatePartLZ( "h", dtmDate )
 
 intMin  = DatePartLZ( "n", dtmDate )
 
 intSec  = DatePartLZ( "s", dtmDate )
 
 If blnDate Then strISO = intYear & "-" & intMonth & "-" & intDay
 
 If blnTime Then strISO = strISO & " " & intHour & ":" & intMin & ":" & intSec
 
 ' Display the result
 
 WScript.Echo Trim( strISO )
 
 Function DatePartLZ( myInterval, myDate )
 
 ' Add a leading zero to the DatePart() if necessary
 
 Dim strDatePart
 
 strDatePart = DatePart( myInterval, myDate )
 
 If Len( strDatePart ) < 2 Then strDatePart = "0" & strDatePart
 
 DatePartLZ = strDatePart
 
 End Function
 
 Sub Syntax
 
 WScript.Echo vbcrlf _
 
 & "Date2ISO.vbs, Version 1.02" _
 
 & vbCrLf _
 
 & "Convert any date/time to ISO date/time" _
 
 & vbCrLf & vbCrLf _
 
 & "Usage: CSCRIPT.EXE //NoLogo Date2ISO.vbs date [ time ] [ /D | /T ]" _
 
 & vbCrLf & vbCrLf _
 
 & "Where: ""date""  is the date to convert (default: current date/time)" _
 
 & vbCrLf _
 
 & "    ""time""  is the optional time to convert" _
 
 & vbCrLf _
 
 & "    /D    return date only (default: both date and time)" _
 
 & vbCrLf _
 
 & "    /T    return time only (/D and /T are mutually exclusive)" _
 
 & vbCrLf & vbCrLf _
 
 & "Note:  If the specified date is ambiguous, the current user's date" _
 
 & vbCrLf _
 
 & "    and time format is assumed." _
 
 & vbCrLf & vbCrLf _
 
 & "Written by Rob van der Woude" _
 
 & vbCrLf _
 
 & "http://www.robvanderwoude.com"
 
 WScript.Quit 1
 
 End Sub
 
 附上一段VBS校对系统时间的代码给大家参考下
 
 'VBS校准系统时间 BY BatMan
 
 Dim objXML, Url, Message
 
 Message = "恭喜你,本机时间非常准确无需校对!"
 
 Set objXML = CreateObject("MSXML2.XmlHttp")
 
 Url = "http://open.baidu.com/special/time/"
 
 objXML.open "GET", Url, False
 
 objXML.send()
 
 Do Until objXML.readyState = 4 : WScript.Sleep 200 : Loop
 
 Dim objStr, LocalDate
 
 objStr = objXML.responseText
 
 LocalDate = Now()
 
 Set objXML = Nothing
 
 Dim objREG, regNum
 
 Set objREG = New RegExp
 
 objREG.Global = True
 
 objREG.IgnoreCase = True
 
 objREG.Pattern = "window.baidu_time\((\d{13,})\)"
 
 regNum = Int(objREG.Execute(objStr)(0)。Submatches(0)) /1000
 
 Dim OldDate, BJDate, Num, Num1
 
 OldDate = "1970-01-01 08:00:00"
 
 BJDate = DateAdd("s", regNum, OldDate)
 
 Num = DateDiff("s", LocalDate, BJDate)
 
 If Abs(Num) >=1 Then
 
 Dim DM, DT, TM, objSHELL
 
 DM = DateAdd("S", Num, Now())
 
 DT = DateValue(DM)
 
 TM = TimeValue(DM)
 
 If InStr(Now, "午") Then
 
 Dim Arr, Arr1, h24
 
 Arr = Split(TM, " ")
 
 Arr1 = Split(Arr(1), ":")
 
 h24 = Arr1(0)
 
 If Arr(0) = "下午" Then
 
 h24 = h24 + 12
 
 Else
 
 If h24 = 12 Then h24 = 0
 
 End If
 
 TM = h24 & ":" & Arr1(1) & ":" & Arr1(2)
 
 End If
 
 Set objSHELL = CreateObject("Wscript.Shell")
 
 objSHELL.Run "cmd /cdate " & DT, False, True
 
 objSHELL.Run "cmd /ctime " & TM, False, True
 
 Num1 = Abs(DateDiff("s", Now(), BJDate))
 
 Message = "【校准前】" & vbCrLf _
 
 & "标准北京时间为:" & vbTab & BJDate & vbCrLf _
 
 & "本机系统时间为:" & vbTab & LocalDate & vbCrLf _
 
 & "与标准时间相差:" & vbTab & Abs(Num) & "秒" & vbCrLf & vbCrLf _
 
 & "【校准后】" & vbCrLf _
 
 & "本机系统时间为:" & vbTab & Now() & vbCrLf _
 
 & "与标准时间相差:" & vbTab & Num1 & "秒"
 
 Set objSHELL = Nothingwww.9ask.cn/zhuzhou/
 
 End If
 
 WScript.Echo Message
 | 
 |