Working With JSON Data in Python
Last Updated :
03 Jun, 2022
JSON is JavaScript Object Notation. It means that a script (executable) file which is made of text in a programming language, is used to store and transfer the data. Python supports JSON through a built-in package called JSON. To use this feature, we import the JSON package in Python script. The text in JSON is done through quoted-string which contains the value in key-value mapping within { }. It is similar to the dictionary in Python. JSON shows an API similar to users of Standard Library marshal and pickle modules and Python natively supports JSON features. For example:
Python3
# Python program showing
# use of json package
import json
# {key:value mapping}
a ={"name":"John",
"age":31,
"Salary":25000}
# conversion to JSON done by dumps() function
b = json.dumps(a)
# printing the output
print(b)
Output:
{"age": 31, "Salary": 25000, "name": "John"}
As you can see, JSON supports primitive types, like strings and numbers, as well as nested lists, tuples, and objects
Python3
# Python program showing that
# json support different primitive
# types
import json
# list conversion to Array
print(json.dumps(['Welcome', "to", "GeeksforGeeks"]))
# tuple conversion to Array
print(json.dumps(("Welcome", "to", "GeeksforGeeks")))
# string conversion to String
print(json.dumps("Hi"))
# int conversion to Number
print(json.dumps(123))
# float conversion to Number
print(json.dumps(23.572))
# Boolean conversion to their respective values
print(json.dumps(True))
print(json.dumps(False))
# None value to null
print(json.dumps(None))
Output:
["Welcome", "to", "GeeksforGeeks"]
["Welcome", "to", "GeeksforGeeks"]
"Hi"
123
23.572
true
false
null
Serializing JSON:
The process of encoding JSON is usually called serialization. This term refers to the transformation of data into a series of bytes (hence serial) to be stored or transmitted across a network. To handle the data flow in a file, the JSON library in Python uses dump() function to convert the Python objects into their respective JSON object, so it makes it easy to write data to files. See the following table given below.
Python object | JSON object |
---|
dict | object |
---|
list, tuple | array |
---|
str | string |
---|
int, long, float | numbers |
---|
True | true |
---|
False | false |
---|
None | null |
---|
Example: Serialization
Consider the given example of a Python object.
Python3
var = {
"Subjects": {
"Maths":85,
"Physics":90
}
}
Using Python's context manager, create a file named Sample.json and open it with write mode.
Python3
with open("Sample.json", "w") as p:
json.dump(var, p)
Here, the dump() takes two arguments first, the data object to be serialized, and second the object to which it will be written(Byte format).
Deserializing JSON:
Deserialization is the opposite of Serialization, i.e. conversion of JSON objects into their respective Python objects. The load() method is used for it. If you have used JSON data from another program or obtained it as a string format of JSON, then it can easily be deserialized with load(), which is usually used to load from a string, otherwise, the root object is in a list or dict.
Python3
with open("Sample.json", "r") as read_it:
data = json.load(read_it)
Example: Deserialization
Python3
json_var ="""
{
"Country": {
"name": "INDIA",
"Languages_spoken": [
{
"names": ["Hindi", "English", "Bengali", "Telugu"]
}
]
}
}
"""
var = json.loads(json_var)
Encoding and Decoding:
Encoding is defined as converting the text or values into an encrypted form that can only be used by the desired user through decoding it. Here encoding and decoding is done for JSON (object)format. Encoding is also known as Serialization and Decoding is known as Deserialization. Python has a popular package for this operation. This package is known as Demjson. To install it follow the steps below.
For Windows:
pip install demjson
For Ubuntu:
sudo apt-get update
sudo apt-get install python-demjson
Encoding: The encode() function is used to convert the python object into a JSON string representation.
Syntax:
demjson.encode(self, obj, nest_level=0)
Example 1: Encoding using demjson package.
Python3
# storing marks of 3 subjects
var = [{"Math": 50, "physics":60, "Chemistry":70}]
print(demjson.encode(var))
Output:
[{"Chemistry":70, "Math":50, "physics":60}]
Decoding: The decode() function is used to convert the JSON object into python-format type.
Syntax:
demjson.decode(self, obj)
Example 2: Decoding using demjson package
Python3
var = '{"a":0, "b":1, "c":2, "d":3, "e":4}'
text = demjson.decode(var)
Output:
{'a': 0, 'b': 1, 'c': 2, 'd': 3, 'e': 4}
Example 3: Encoding using iterencode package
Python3
# Other Method of Encoding
json.JSONEncoder().encode({"foo": ["bar"]})
'{"foo": ["bar"]}'
# Using iterencode(object) to encode a given object.
for i in json.JSONEncoder().iterencode(bigobject):
mysocket.write(i)
Example 4: Encoding and Decoding using dumps() and loads().
Python3
# To encode and decode operations
import json
var = {'age':31, 'height':6}
x = json.dumps(var)
y = json.loads(x)
print(x)
print(y)
# when performing from a file in disk
with open("any_file.json", "r") as readit:
x = json.load(readit)
print(x)
Command-Line Usage
The JSON library can also be used from the command-line, to validate and pretty-print your JSON.
$ echo "{ \"name\": \"Monty\", \"age\": 45 }"

Searching through JSON with JMESPath
JMESPath is a query language for JSON. It allows you to easily obtain the data you need from a JSON document. If you ever worked with JSON before, you probably know that it's easy to get a nested value. For example, doc["person"]["age"] will get you the nested value for age in a document.
First, install jmespath :
$ pip3 install jmespath

Real-World Example:
Let us take a real-life example of the implementation of the JSON in python. A good source for practice purposes is JSON_placeholder, it provides a great API requests package which we will be using in our example. To get started, follow these simple steps. Open Python IDE or CLI and create a new script file, name it sample.py.
Python3
import requests
import json
# Now we have to request our JSON data through
# the API package
res = requests.get("https://jsonplaceholder.typicode.com / todos")
var = json.loads(res.text)
# To view your Json data, type var and hit enter
var
# Now our Goal is to find the User who have
# maximum completed their task !!
# i.e we would count the True value of a
# User in completed key.
# {
# "userId": 1,
# "id": 1,
# "title": "Hey",
# "completed": false, # we will count
# this for a user.
# }
# Note that there are multiple users with
# unique id, and their task have respective
# Boolean Values.
def find(todo):
check = todo["completed"]
max_var = todo["userId"] in users
return check and max_var
# To find the values.
Value = list(filter(find, todos))
# To write these value to your disk
with open("sample.json", "w") as data:
Value = list(filter(keep, todos))
json.dump(Value, data, indent = 2)
To know more, Click Here
Similar Reads
How to Work with JSON Data in Ruby?
JSON, which stands for JavaScript Object Notation, is a format used to exchange data between different systems. It is popular because it is easy for both computers and humans to understand. This article focuses on discussing working with JSON data in Ruby. Table of Content Installing the JSON GemPar
3 min read
Visualizing JSON Data in Python
The JSON (JavaScript Object Notation) is a lightweight data interchange format that is easy to the read and write for humans and machines alike. The Visualizing JSON data can help in the understanding its structure and the relationships between its elements. This article will guide we through differ
5 min read
Working with csv files in Python
Python is one of the important fields for data scientists and many programmers to handle a variety of data. CSV (Comma-Separated Values) is one of the prevalent and accessible file formats for storing and exchanging tabular data. In article explains What is CSV. Working with CSV files in Python, Rea
10 min read
Working with JSON Files in R Programming
JSON stands for JavaScript Object Notation. These files contain the data in human readable format, i.e. as text. Like any other file, one can read as well as write into the JSON files. In order to work with JSON files in R, one needs to install the "rjson" package. The most common tasks done using J
4 min read
Reading and Writing JSON to a File in Python
The full form of JSON is Javascript Object Notation. It means that a script (executable) file which is made of text in a programming language, is used to store and transfer the data. Python supports JSON through a built-in package called JSON. To use this feature, we import the JSON package in Pytho
3 min read
JSON with Python
JSON Â (JavaScript Object Notation) is a file that is mainly used to store and transfer data mostly between a server and a web application. It is popularly used for representing structured data. In this article, we will discuss how to handle JSON data using Python. Python provides a module called jso
5 min read
Loop through a JSON array in Python
A JSON array is an ordered list of values that can store multiple values such as string, number, boolean, or object. The values in a JSON array must be separated by commas and enclosed in squares in brackets []. In this article, we will learn how we can loop through a JSON array in Python. Iterate o
4 min read
Append to JSON file using Python
The full form of JSON is JavaScript Object Notation. It means that a script (executable) file which is made of text in a programming language, is used to store and transfer the data. Python supports JSON through a built-in package called JSON. To use this feature, we import the JSON package in Pytho
2 min read
How to JSON decode in Python?
When working with JSON data in Python, we often need to convert it into native Python objects. This process is known as decoding or deserializing. The json module in Python provides several functions to work with JSON data, and one of the essential tools is the json.JSONDecoder() method. This method
5 min read
Fetch JSON URL Data and Store in Excel using Python
In this article, we will learn how to fetch the JSON data from a URL using Python, parse it, and store it in an Excel file. We will use the Requests library to fetch the JSON data and Pandas to handle the data manipulation and export it to Excel.Fetch JSON data from URL and store it in an Excel file
3 min read