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
(Tcl) 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
load ./chilkat.dll set json [new_CkJsonObject] CkJsonObject_put_EmitCompact $json 0 # First, let's create JSON containing some date/time strings. CkJsonObject_UpdateString $json "test.timestamp" "2018-01-30T20:35:00Z" CkJsonObject_UpdateString $json "test.rfc822" "Tue, 24 Apr 2018 08:47:03 -0500" CkJsonObject_UpdateString $json "test.dateStrings[0]" "2018-01-30T20:35:00Z" CkJsonObject_UpdateString $json "test.dateStrings[1]" "Tue, 24 Apr 2018 08:47:03 -0500" CkJsonObject_UpdateNumber $json "test.StartLoggingTime" "1446834998.695" CkJsonObject_UpdateNumber $json "test.Expiration" "1442877512.0" CkJsonObject_UpdateInt $json "test.StartTime" 1518867432 puts [CkJsonObject_emit $json] # 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. set dateTime [new_CkDateTime] set dt [new_CkDtObj] set getAsLocal 0 # Load the date/time at test.timestamp into the dateTime object. set success [CkJsonObject_DateOf $json "test.timestamp" $dateTime] puts [CkDateTime_getAsTimestamp $dateTime $getAsLocal] puts [CkDateTime_GetAsUnixTime $dateTime 0] puts [CkDateTime_getAsRfc822 $dateTime $getAsLocal] set success [CkJsonObject_DateOf $json "test.rfc822" $dateTime] puts [CkDateTime_getAsTimestamp $dateTime $getAsLocal] CkJsonObject_put_I $json 0 set success [CkJsonObject_DateOf $json "test.dateStrings[i]" $dateTime] puts [CkDateTime_getAsTimestamp $dateTime $getAsLocal] CkJsonObject_put_I $json 1 set success [CkJsonObject_DateOf $json "test.dateStrings[i]" $dateTime] puts [CkDateTime_getAsTimestamp $dateTime $getAsLocal] set success [CkJsonObject_DateOf $json "test.StartLoggingTime" $dateTime] puts [CkDateTime_getAsTimestamp $dateTime $getAsLocal] set success [CkJsonObject_DateOf $json "test.Expiration" $dateTime] puts [CkDateTime_getAsTimestamp $dateTime $getAsLocal] set success [CkJsonObject_DateOf $json "test.StartTime" $dateTime] puts [CkDateTime_getAsTimestamp $dateTime $getAsLocal] # 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: set success [CkJsonObject_DtOf $json "test.timestamp" $getAsLocal $dt] puts "month=[CkDtObj_get_Month $dt], day=[CkDtObj_get_Day $dt], year=[CkDtObj_get_Year $dt], hour=[CkDtObj_get_Hour $dt], minute=[CkDtObj_get_Minute $dt]" set success [CkJsonObject_DtOf $json "test.rfc822" $getAsLocal $dt] puts "month=[CkDtObj_get_Month $dt], day=[CkDtObj_get_Day $dt], year=[CkDtObj_get_Year $dt], hour=[CkDtObj_get_Hour $dt], minute=[CkDtObj_get_Minute $dt]" CkJsonObject_put_I $json 0 set success [CkJsonObject_DtOf $json "test.dateStrings[i]" $getAsLocal $dt] puts "month=[CkDtObj_get_Month $dt], day=[CkDtObj_get_Day $dt], year=[CkDtObj_get_Year $dt], hour=[CkDtObj_get_Hour $dt], minute=[CkDtObj_get_Minute $dt]" CkJsonObject_put_I $json 1 set success [CkJsonObject_DtOf $json "test.dateStrings[i]" $getAsLocal $dt] puts "month=[CkDtObj_get_Month $dt], day=[CkDtObj_get_Day $dt], year=[CkDtObj_get_Year $dt], hour=[CkDtObj_get_Hour $dt], minute=[CkDtObj_get_Minute $dt]" set success [CkJsonObject_DtOf $json "test.StartLoggingTime" $getAsLocal $dt] puts "month=[CkDtObj_get_Month $dt], day=[CkDtObj_get_Day $dt], year=[CkDtObj_get_Year $dt], hour=[CkDtObj_get_Hour $dt], minute=[CkDtObj_get_Minute $dt]" set success [CkJsonObject_DtOf $json "test.Expiration" $getAsLocal $dt] puts "month=[CkDtObj_get_Month $dt], day=[CkDtObj_get_Day $dt], year=[CkDtObj_get_Year $dt], hour=[CkDtObj_get_Hour $dt], minute=[CkDtObj_get_Minute $dt]" set success [CkJsonObject_DtOf $json "test.StartTime" $getAsLocal $dt] puts "month=[CkDtObj_get_Month $dt], day=[CkDtObj_get_Day $dt], year=[CkDtObj_get_Year $dt], hour=[CkDtObj_get_Hour $dt], minute=[CkDtObj_get_Minute $dt]" # 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 delete_CkJsonObject $json delete_CkDateTime $dateTime delete_CkDtObj $dt |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.