Visual FoxPro
Visual FoxPro
Iterate JSON where Member Names are Data Values
See more JSON Examples
Demonstrates how to parse JSON where member names are not keywords, but instead are data values.Chilkat Visual FoxPro Downloads
LOCAL lnSuccess
LOCAL loJson
LOCAL lnNumMembers
LOCAL i
LOCAL lcName
LOCAL loJRecord
lnSuccess = 0
loJson = CreateObject('Chilkat.JsonObject')
lnSuccess = loJson.LoadFile("qa_data/json/valuesAsNames.json")
* Imagine we have JSON such as the following:
* {
* "1680": {
* "entity_id": "1680",
* "type_id": "simple",
* "sku": "123"
* },
* "1701": {
* "entity_id": "1701",
* "type_id": "simple",
* "sku": "456"
* }
* }
*
* This presents a parsing problem because the member names, such as "1680"
* are not keywords. Instead they are data values. We don't know what they
* may be in advance.
* To solve, we iterate over the members, get the name of each, ...
lnNumMembers = loJson.Size
FOR i = 0 TO lnNumMembers - 1
lcName = loJson.NameAt(i)
? lcName + ":"
loJRecord = loJson.ObjectAt(i)
? "entity_id: " + loJRecord.StringOf("entity_id")
? "type_id: " + loJRecord.StringOf("type_id")
? "sku: " + loJRecord.StringOf("sku")
RELEASE loJRecord
NEXT
RELEASE loJson