|  | 
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) Demonstrates how to Handle Large Integers in JSONSee more JSON ExamplesDemonstrates how to handle large integers in JSON. (Integers larger than what can fit in a 32-bit signed integer.)
 load ./chilkat.dll # Let's say your JSON has this: # { # "id": 20000000001234567 # } set json [new_CkJsonObject] set success [CkJsonObject_LoadFile $json "qa_data/json/large_int.json"] if {$success == 0} then { puts [CkJsonObject_lastErrorText $json] delete_CkJsonObject $json exit } # The integer is too large for a 32-bit signed integer that is returned by IntOf. # The result will be something that wrapped around and could be negative. # In this case it would be: -543893881 set id [CkJsonObject_IntOf $json "id"] puts "id: $id" # The solution is to read the integer value as a string, and then use the features in your programming language # to convert from a string to a 64-bit integer. # # Alternatively, you may wish to simply hold the value as a string. If, for example, the integer simply references # an order ID, an account ID, etc., then there's no need to convert to an integer value. You're not going to be doing # mathematical operations on it anyway. This is usually the case for large integers -- they typically exist # in JSON as an account ID. # You can get any JSON value as a string: set accountId [CkJsonObject_stringOf $json "id"] puts "accountId: $accountId" # Sample output: # id: -543893881 # accountId: 20000000001234567 delete_CkJsonObject $json | ||||
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.