Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(AutoIt) JSON Date ParsingDemonstrates how to parse date/time strings from JSON. Note: This example uses the DtOf and DateOf methods introduced in Chilkat v9.5.0.73
Local $bSuccess $oJson = ObjCreate("Chilkat.JsonObject") $oJson.EmitCompact = False ; First, let's create JSON containing some date/time strings. $oJson.UpdateString("test.timestamp","2018-01-30T20:35:00Z") $oJson.UpdateString("test.rfc822","Tue, 24 Apr 2018 08:47:03 -0500") $oJson.UpdateString("test.dateStrings[0]","2018-01-30T20:35:00Z") $oJson.UpdateString("test.dateStrings[1]","Tue, 24 Apr 2018 08:47:03 -0500") $oJson.UpdateNumber("test.StartLoggingTime","1446834998.695") $oJson.UpdateNumber("test.Expiration","1442877512.0") $oJson.UpdateInt("test.StartTime",1518867432) ConsoleWrite($oJson.Emit() & @CRLF) ; We've built the following JSON: ; { ; "test": { ; "timestamp": "2018-01-30T20:35:00Z", ; "rfc822": "Tue, 24 Apr 2018 08:47:03 -0500", ; "dateStrings": [ ; "2018-01-30T20:35:00Z", ; "Tue, 24 Apr 2018 08:47:03 -0500" ; ], ; "StartLoggingTime": 1446834998.695, ; "Expiration": 1442877512.0, ; "StartTime": 1518867432 ; } ; } ; Use the DateOf and DtOf methods to load Chilkat date/time objects with the date/time values. ; The CkDateTime object is primarily for loading a date/time from numerous formats, and then getting ; the date/time in various formats. Thus, it's primarly for date/time format conversion. ; The DtObj object holds a date/time where the individual components (day, month, year, hour, minutes, etc.) are ; immediately accessible as integers. $oDateTime = ObjCreate("Chilkat.CkDateTime") $oDt = ObjCreate("Chilkat.DtObj") Local $bGetAsLocal = False ; Load the date/time at test.timestamp into the dateTime object. $bSuccess = $oJson.DateOf("test.timestamp",$oDateTime) ConsoleWrite($oDateTime.GetAsTimestamp($bGetAsLocal) & @CRLF) ConsoleWrite($oDateTime.GetAsUnixTime(False) & @CRLF) ConsoleWrite($oDateTime.GetAsRfc822($bGetAsLocal) & @CRLF) $bSuccess = $oJson.DateOf("test.rfc822",$oDateTime) ConsoleWrite($oDateTime.GetAsTimestamp($bGetAsLocal) & @CRLF) $oJson.I = 0 $bSuccess = $oJson.DateOf("test.dateStrings[i]",$oDateTime) ConsoleWrite($oDateTime.GetAsTimestamp($bGetAsLocal) & @CRLF) $oJson.I = 1 $bSuccess = $oJson.DateOf("test.dateStrings[i]",$oDateTime) ConsoleWrite($oDateTime.GetAsTimestamp($bGetAsLocal) & @CRLF) $bSuccess = $oJson.DateOf("test.StartLoggingTime",$oDateTime) ConsoleWrite($oDateTime.GetAsTimestamp($bGetAsLocal) & @CRLF) $bSuccess = $oJson.DateOf("test.Expiration",$oDateTime) ConsoleWrite($oDateTime.GetAsTimestamp($bGetAsLocal) & @CRLF) $bSuccess = $oJson.DateOf("test.StartTime",$oDateTime) ConsoleWrite($oDateTime.GetAsTimestamp($bGetAsLocal) & @CRLF) ; Output so far: ; 2018-01-30T20:35:00Z ; 1517344500 ; Tue, 30 Jan 2018 20:35:00 GMT ; 2018-04-24T13:47:03Z ; 2018-01-30T20:35:00Z ; 2018-04-24T13:47:03Z ; 2015-11-07T00:36:38Z ; 2015-09-22T04:18:32Z ; 2018-02-17T17:37:12Z ; Now load the date/time strings into the dt object: $bSuccess = $oJson.DtOf("test.timestamp",$bGetAsLocal,$oDt) ConsoleWrite("month=" & $oDt.Month & ", day=" & $oDt.Day & ", year=" & $oDt.Year & ", hour=" & $oDt.Hour & ", minute=" _ & $oDt.Minute & @CRLF) $bSuccess = $oJson.DtOf("test.rfc822",$bGetAsLocal,$oDt) ConsoleWrite("month=" & $oDt.Month & ", day=" & $oDt.Day & ", year=" & $oDt.Year & ", hour=" & $oDt.Hour & ", minute=" _ & $oDt.Minute & @CRLF) $oJson.I = 0 $bSuccess = $oJson.DtOf("test.dateStrings[i]",$bGetAsLocal,$oDt) ConsoleWrite("month=" & $oDt.Month & ", day=" & $oDt.Day & ", year=" & $oDt.Year & ", hour=" & $oDt.Hour & ", minute=" _ & $oDt.Minute & @CRLF) $oJson.I = 1 $bSuccess = $oJson.DtOf("test.dateStrings[i]",$bGetAsLocal,$oDt) ConsoleWrite("month=" & $oDt.Month & ", day=" & $oDt.Day & ", year=" & $oDt.Year & ", hour=" & $oDt.Hour & ", minute=" _ & $oDt.Minute & @CRLF) $bSuccess = $oJson.DtOf("test.StartLoggingTime",$bGetAsLocal,$oDt) ConsoleWrite("month=" & $oDt.Month & ", day=" & $oDt.Day & ", year=" & $oDt.Year & ", hour=" & $oDt.Hour & ", minute=" _ & $oDt.Minute & @CRLF) $bSuccess = $oJson.DtOf("test.Expiration",$bGetAsLocal,$oDt) ConsoleWrite("month=" & $oDt.Month & ", day=" & $oDt.Day & ", year=" & $oDt.Year & ", hour=" & $oDt.Hour & ", minute=" _ & $oDt.Minute & @CRLF) $bSuccess = $oJson.DtOf("test.StartTime",$bGetAsLocal,$oDt) ConsoleWrite("month=" & $oDt.Month & ", day=" & $oDt.Day & ", year=" & $oDt.Year & ", hour=" & $oDt.Hour & ", minute=" _ & $oDt.Minute & @CRLF) ; Output: ; month=1, day=30, year=2018, hour=20, minute=35 ; month=4, day=24, year=2018, hour=13, minute=47 ; month=1, day=30, year=2018, hour=20, minute=35 ; month=4, day=24, year=2018, hour=13, minute=47 ; month=11, day=6, year=2015, hour=18, minute=36 ; month=9, day=21, year=2015, hour=23, minute=18 ; month=2, day=17, year=2018, hour=11, minute=37 |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.