Chilkat HOME Android™ Classic ASP C C++ C# Mono C# .NET Core C# C# UWP/WinRT DataFlex Delphi ActiveX Delphi DLL Visual FoxPro Java Lianja MFC Objective-C Perl PHP ActiveX PHP Extension PowerBuilder PowerShell PureBasic CkPython Chilkat2-Python Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ Visual Basic 6.0 VB.NET VB.NET UWP/WinRT VBScript Xojo Plugin Node.js Excel Go
(Excel) 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.)
' Let's say your JSON has this: ' { ' "id": 20000000001234567 ' } Dim json As Chilkat.JsonObject Set json = Chilkat.NewJsonObject success = json.LoadFile("qa_data/json/large_int.json") If (success = False) Then Debug.Print json.LastErrorText Exit Sub End If ' 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 id = json.IntOf("id") Debug.Print "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: accountId = json.StringOf("id") Debug.Print "accountId: "; accountId ' Sample output: ' id: -543893881 ' accountId: 20000000001234567 |
© 2000-2022 Chilkat Software, Inc. All Rights Reserved.