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) Get the Index of a JSON MemberThis example demonstrates how to get the index of a given member by name. { "name": "donut", "image": { "fname": "donut.jpg", "w": 200, "h": 200 }, "thumbnail": { "fname": "donutThumb.jpg", "w": 32, "h": 32 } }
Dim json As Chilkat.JsonObject Set json = Chilkat.NewJsonObject ' This is the above JSON with whitespace chars removed (SPACE, TAB, CR, and LF chars). ' The presence of whitespace chars for pretty-printing makes no difference to the Load ' method. jsonStr = "{""name"": ""donut"",""image"":{""fname"": ""donut.jpg"",""w"": 200,""h"": 200},""thumbnail"":{""fname"": ""donutThumb.jpg"",""w"": 32,""h"": 32}}" success = json.Load(jsonStr) If (success <> True) Then Debug.Print json.LastErrorText Exit Sub End If ' The top-level JSON object has three members: name, image, and thumbnail. nameIndex = json.IndexOf("name") ' The index of the "name" member is 0. Debug.Print "nameIndex = "; nameIndex thumbIndex = json.IndexOf("thumbnail") ' The index of the "thumbnail" member is 2. Debug.Print "thumbIndex = "; thumbIndex ' The "fname" member is NOT a direct member of the top-level JSON object. ' It is a member of a nested object. If we try to get the index of this ' member using the top-level JSON object, it is not found (and returns -1). fnameIndex = json.IndexOf("fname") ' The fnameIndex is -1 (not found). This is correct. Debug.Print "fnameIndex = "; fnameIndex ' Get the "image" object. Set imageObj = json.ObjectOf("image") If (json.LastMethodSuccess = False) Then Debug.Print "image object not found." Exit Sub End If ' Now we can get the index of the "fname" object, because it is a direct ' member of the "image" object: fnameIndex = imageObj.IndexOf("fname") Debug.Print "fnameIndex = "; fnameIndex |
© 2000-2022 Chilkat Software, Inc. All Rights Reserved.