Python XML vers JSON

Python Xml Json



Le langage de balisage extensible (XML) et la notation d'objets JavaScript (JSON) sont deux formats de données célèbres pour le stockage de données. JSON et XML nous permettent de stocker les données de manière lisible par l'homme ainsi que par les machines. Pour commencer, JSON est un type de structure de données qui est principalement utilisé pour échanger des données entre les serveurs et les applications logicielles. Il stocke les données sous forme de paires clé-valeur. JSON crée un objet des données où les paires clé-valeur sont séparées sur la base des deux points (:) et une paire clé-valeur complète séparée par d'autres en fonction de la virgule.







De plus, XML est un langage de balisage de type HTML qui est également utilisé pour stocker les données. Mais, le XML ne fournit aucun type de balises prédéfinies. Nous pouvons créer nos propres balises et stocker les données. Comme nous l'avons vu, JSON et XML sont utilisés pour échanger des données entre les serveurs et les applications logicielles. Cependant, les deux formats de données diffèrent quelque peu. Le JSON est un format de stockage de données de type objet, alors que XML n'a pas de type. Les fichiers XML stockent uniquement les données au format chaîne et plus lourds que le fichier JSON. Alors que les fichiers JSON peuvent stocker la chaîne, les tableaux, les nombres à virgule flottante et les valeurs booléennes.



Cet article explique la conversion XML en JSON à l'aide de Python. Le module Python xmltodict est utilisé pour convertir le format XML au format JSON.



L'installation du module xmltodict

Avant de commencer à convertir XML en JSON, nous devons installer le module xmltodict. Le module xmltodict peut être installé à l'aide du package d'index python (pip), et il peut être installé dans Python 2 et 3. Dans le cas de pip2, exécutez la commande suivante pour installer le module xmltodict :





pip installer xmltodict

Si vous utilisez pip3, exécutez la commande suivante pour installer le module xmltodict :

pip3 installer xmltodict



Dans le cas d'un système basé sur Debian, exécutez la commande suivante pour installer le module xmltodict :

sudo apt installer python-xmltodict

La commande ci-dessus convient à Python2. Dans le cas de la version Python3, exécutez la commande suivante :

sudo apt installer python3-xmltodict

Conversion XML en JSON

Convertissons maintenant les données XML au format JSON. Nous utiliserons le module xmltodict et JSON pour cette conversion. Le json est un module Python intégré. Par conséquent, la nécessité de les installer est éliminée. La fonction xmltodict.parse() convertit les données XML en dictionnaire Python. Ensuite, la fonction json.dumps() prend l'objet dictionnaire converti comme argument et le convertit davantage au format JSON. Il s'agit donc d'un processus en deux étapes :

Nous devons d'abord convertir l'objet de dictionnaire XML en Python à l'aide de la fonction xmltodict.parse().

Deuxièmement, nous convertissons l'objet du dictionnaire Python au format JSON à l'aide de la fonction json.dumps(). Dans la fonction json.dumps(), la propriété indent est utilisée pour ajouter des espaces entre les données.

#importation des modules
importerxmltodict
importerjson
#déclarer le xml
mon_xml= '' '


1
Les Jardins du Marais
3
l'Internet
Vrai


2
Petit Palais Golden Tulip
4

l'Internet
Gym
Parking
Restaurant

Faux


'' '

#coverting xml to Python Dictionary
dict_data=xmltodict.analyser(mon_xml)
#coverting vers json
json_data=json.décharges(dict_data,retrait=2)
imprimer(json_data)

Sortir

La sortie montre que le XML est converti avec succès au format JSON.

Conversion de fichier XML en fichier JSON

Les données des fichiers XML peuvent être converties et enregistrées dans le fichier JSON. Ouvrons le fichier XML, convertissons les données XML en JSON et stockons-les dans un fichier JSON.

Ce qui suit est le fichier XML.

#importation des modules
importerjson
importerxmltodict
# ouverture du fichier xml
avec ouvert('hotels.xml','r') commexmlfileObj :
#conversion des données XML en dictionnaire
data_dict=xmltodict.analyser(xmlfileObj.lire())
xmlfileObj.proche()
#création d'un objet JSON à l'aide d'un objet dictionnaire
jsonObj=json.décharges(data_dict)

#stockage des données json dans un fichier json
avec ouvert('hotels.json', 'dans') commejsonfileObj :
jsonfileObj.écrivez(jsonObj)
jsonfileObj.proche()

Sortir

L'interpréteur Python n'affiche aucune erreur ; cela signifie que les données JSON sont enregistrées avec succès dans un fichier .json.

Conclusion

XML et JSON sont deux formats de données populaires pour stocker des données. Les données XML peuvent être converties au format JSON à l'aide des modules xmltodict et JSON. Cet article explique la conversion de données XML en JSON avec des exemples.