PowerShell
PowerShell
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 PowerShell Downloads
Add-Type -Path "C:\chilkat\ChilkatDotNet47-x64\ChilkatDotNet47.dll"
$success = $false
$json = New-Object Chilkat.JsonObject
# Load the JSON from a file.
$success = $json.LoadFile("qa_data/json/modifySample.json")
if ($success -eq $false) {
$($json.LastErrorText)
exit
}
# This example will not check for errors (i.e. null / false / 0 return values)...
# Get the "list" array:
$listA = New-Object Chilkat.JsonArray
$json.ArrayOf2("list",$listA)
# Modify values in the list.
# Change banana to plantain
$success = $listA.SetStringAt(0,"plantain")
# Change 12 to 24
$success = $listA.SetIntAt(1,24)
# Change true to false
$success = $listA.SetBoolAt(2,$false)
# Is the 3rd item null?
$bNull = $listA.IsNullAt(3)
# Change "orange" to 32.
$success = $listA.SetIntAt(4,32)
# Change 12.5 to 31.2
$success = $listA.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.
$success = $listA.DeleteAt(6)
$tickerObj = New-Object Chilkat.JsonObject
$listA.AddObjectAt2(6,$tickerObj)
$success = $tickerObj.AppendString("ticker","GOOG")
# Replace "[ 1, 2, 3, 4, 5 ]" with "[ "apple", 22, true, null, 1080.25 ]"
$success = $listA.DeleteAt(7)
$aa = New-Object Chilkat.JsonArray
$listA.AddArrayAt2(7,$aa)
$success = $aa.AddStringAt(-1,"apple")
$success = $aa.AddIntAt(-1,22)
$success = $aa.AddBoolAt(-1,$true)
$success = $aa.AddNullAt(-1)
$success = $aa.AddNumberAt(-1,"1080.25")
# Get the "fruit" array
$aFruit = New-Object Chilkat.JsonArray
$json.ArrayAt2(0,$aFruit)
# Get the 1st element:
$appleObj = New-Object Chilkat.JsonObject
$aFruit.ObjectAt2(0,$appleObj)
# Modify values by member name:
$success = $appleObj.SetStringOf("fruit","fuji_apple")
$success = $appleObj.SetIntOf("count",46)
$success = $appleObj.SetBoolOf("fresh",$false)
$success = $appleObj.SetStringOf("extraInfo","developed by growers at the Tohoku Research Station in Fujisaki")
# Modify values by index:
$pearObj = New-Object Chilkat.JsonObject
$aFruit.ObjectAt2(1,$pearObj)
$success = $pearObj.SetStringAt(0,"bartlett_pear")
$success = $pearObj.SetIntAt(1,12)
$success = $pearObj.SetBoolAt(2,$false)
$success = $pearObj.SetStringAt(3,"harvested in late August to early September")
$json.EmitCompact = $false
$($json.Emit())