Visual FoxPro
Visual FoxPro
Modify Parts of JSON Document
See more JSON Examples
Demonstrates how to modify parts of a JSON document. This example uses the following JSON document:
{
"fruit": [
{
"kind": "apple",
"count": 24,
"fresh": true,
"extraInfo": null,
"listA": [ "abc", 1, null, false ],
"objectB": { "animal" : "monkey" }
},
{
"kind": "pear",
"count": 18,
"fresh": false,
"extraInfo": null
"listA": [ "xyz", 24, null, true ],
"objectB": { "animal" : "lemur" }
}
],
"list" : [ "banana", 12, true, null, "orange", 12.5, { "ticker": "AAPL" }, [ 1, 2, 3, 4, 5 ] ],
"alien" : true
}
Chilkat Visual FoxPro Downloads
LOCAL lnSuccess
LOCAL loJson
LOCAL loListA
LOCAL lnBNull
LOCAL loTickerObj
LOCAL loAa
LOCAL loAFruit
LOCAL loAppleObj
LOCAL loPearObj
lnSuccess = 0
loJson = CreateObject('Chilkat.JsonObject')
* Load the JSON from a file.
lnSuccess = loJson.LoadFile("qa_data/json/modifySample.json")
IF (lnSuccess = 0) THEN
? loJson.LastErrorText
RELEASE loJson
CANCEL
ENDIF
* This example will not check for errors (i.e. null / false / 0 return values)...
* Get the "list" array:
loListA = CreateObject('Chilkat.JsonArray')
loJson.ArrayOf2("list",loListA)
* Modify values in the list.
* Change banana to plantain
lnSuccess = loListA.SetStringAt(0,"plantain")
* Change 12 to 24
lnSuccess = loListA.SetIntAt(1,24)
* Change true to false
lnSuccess = loListA.SetBoolAt(2,0)
* Is the 3rd item null?
lnBNull = loListA.IsNullAt(3)
* Change "orange" to 32.
lnSuccess = loListA.SetIntAt(4,32)
* Change 12.5 to 31.2
lnSuccess = loListA.SetNumberAt(5,"31.2")
* Replace the { "ticker" : "AAPL" } object with { "ticker" : "GOOG" }
* Do this by deleting, then inserting a new object at the same location.
lnSuccess = loListA.DeleteAt(6)
loTickerObj = CreateObject('Chilkat.JsonObject')
loListA.AddObjectAt2(6,loTickerObj)
lnSuccess = loTickerObj.AppendString("ticker","GOOG")
* Replace "[ 1, 2, 3, 4, 5 ]" with "[ "apple", 22, true, null, 1080.25 ]"
lnSuccess = loListA.DeleteAt(7)
loAa = CreateObject('Chilkat.JsonArray')
loListA.AddArrayAt2(7,loAa)
lnSuccess = loAa.AddStringAt(-1,"apple")
lnSuccess = loAa.AddIntAt(-1,22)
lnSuccess = loAa.AddBoolAt(-1,1)
lnSuccess = loAa.AddNullAt(-1)
lnSuccess = loAa.AddNumberAt(-1,"1080.25")
* Get the "fruit" array
loAFruit = CreateObject('Chilkat.JsonArray')
loJson.ArrayAt2(0,loAFruit)
* Get the 1st element:
loAppleObj = CreateObject('Chilkat.JsonObject')
loAFruit.ObjectAt2(0,loAppleObj)
* Modify values by member name:
lnSuccess = loAppleObj.SetStringOf("fruit","fuji_apple")
lnSuccess = loAppleObj.SetIntOf("count",46)
lnSuccess = loAppleObj.SetBoolOf("fresh",0)
lnSuccess = loAppleObj.SetStringOf("extraInfo","developed by growers at the Tohoku Research Station in Fujisaki")
* Modify values by index:
loPearObj = CreateObject('Chilkat.JsonObject')
loAFruit.ObjectAt2(1,loPearObj)
lnSuccess = loPearObj.SetStringAt(0,"bartlett_pear")
lnSuccess = loPearObj.SetIntAt(1,12)
lnSuccess = loPearObj.SetBoolAt(2,0)
lnSuccess = loPearObj.SetStringAt(3,"harvested in late August to early September")
loJson.EmitCompact = 0
? loJson.Emit()
RELEASE loJson
RELEASE loListA
RELEASE loTickerObj
RELEASE loAa
RELEASE loAFruit
RELEASE loAppleObj
RELEASE loPearObj