jsonwiz is a command-line tool for working with JSON files. You can retrieve, modify, add or delete any value in the JSON file, then save the changes back to disk. To access a specific property deep in the tree, you can navigate nested objects and arrays using the dot (.) or slash (/) syntax.
jsonwiz can be installed via pip through PyPi
pip install jsonwiz
Once jsonwiz is installed, you can use the following command to interact with the cli
jsonwiz COMMAND [FILE] [PATH] [VALUE] [--ARGS]
COMMAND | Command to run |
FILE | Path to JSON file |
PATH | Key name or path (dot notation or slash notation) |
VALUE | The new value for `set` command |
ARGS | Optional arguments to pass. Check below |
jsonwiz set example.json person.name "John" --type string
This would write a name
key into the person
object, and set the value to John
as a string
"person": {
"name": "John"
}
The get
command fetches an existing value, and outputs it to the console.
jsonwiz get example.json person.name
The set
command will create or replace a key. If the key exists, it will override the exisiting value. It also automatically creates any parent objects if necessary.
jsonwiz set example.json person.age 32 --type string
The data type of the new value is guessed by the format. To assert required data type, pass the --type
argument. Read about it here.
The delete
command will delete an existing key, and fail if the key or any parent objects don't exist.
jsonwiz delete example.json person.age
The validate
command simply checks if the input JSON is valid or not.
jsonwiz validate example.json
The --type
is an optional argument to specify the data type of the new value. To be used with the set
command.
Supported types are - string
, integer
, float
, boolean
, null
and object
Example: Pass a boolean
value
jsonwiz set example.json person.subscribed true --type boolean
Output:
{
"person": {
"name": "John",
"subscribed": true
}
}
It is possible to add entire JSON fragments to your file by replacing an existing object/creating a new object. Recommended to use --type
object to correctly parse your value as JSON when applying to the document. Make sure to properly escape your quotes when attempting this.
jsonwiz set example.json person.address '{\"city\":\"Mumbai\"}' --type object
Output:
"person": {
"address": {
"city": "Mumbai"
}
}
You can traverse arrays just like any other object, simply by specifying the array index as the key. Make sure to use --type
object for array insertions to work properly. Make sure to properly escape your quotes when attempting this.
Sample JSON
{
"person": {
"address": {
"city": "Mumbai"
},
"items": [
{
"name": "item1"
},
{
"name": "item2"
}
]
}
}
jsonwiz get example.json person.items.0.name
- Create empty array
jsonwiz get example.json person.jobs [] --type object
- Create arrays with no strings
jsonwiz get example.json person.jobs [1,2,3] --type object
- Create arrays with string values
jsonwiz my_list '[\"value1\", \"value2\", \"value3\"]' --type object