Maison > développement back-end > Tutoriel Python > Comment utiliser la bibliothèque standard json de Python

Comment utiliser la bibliothèque standard json de Python

PHPz
Libérer: 2023-06-03 12:25:59
avant
1454 Les gens l'ont consulté

"Comment

1. Aperçu des bases de JSON

1.

JSON (nom complet : JavaScript Object Notation) est un format d'échange de données texte léger. Le format de données de JSON est en fait le format de dictionnaire en Python, qui peut contenir des tableaux entre crochets, qui est une liste en python. . "JSON est indépendant du langage" est le format JSON

  • 2. À quoi ressemble JSON ?

  • Format de syntaxe

     : {key1:value1, key2:value2,} Format de paire clé-valeur (séparés par deux points), reliés par des virgules

  • Cas simple

     : objet JSON

    {
        "name": "小明", 
        "age": 18}
    Copier après la connexion
  • Cas complexe

     : tableau JSON

    {
        "student":
            [
                {"name": "小明", "age": 11},
                {"name": "小红","age": 10}
            ],
        "classroom": {"class1": "room1", "class2": "room2"}}
    Copier après la connexion
  • 3. Notes

1. La partie clé de la paire clé-valeur json doit être entourée de guillemets doubles ", les guillemets simples ne fonctionneront pas (donc si dans Les mots-clés apparaissent dans la clé et sont caractérisés), mais il n'y a aucune exigence obligatoire pour les objets en js (les mots-clés ne sont donc pas autorisés dans la clé)

2 Les fonctions ne sont pas autorisées dans la partie valeur de la paire clé-valeur de. json. fonction, non définie, NaN, mais peut avoir null, qui peut apparaître dans la valeur de l'objet dans js 3 Une fois les données json terminées, les virgules dénuées de sens ne sont pas autorisées, telles que : {"name. ":"admin" ,"age":18,}, faites attention à la virgule après 18 à la fin des données, ce qui n'est pas autorisé. {key1:value1, key2:value2,} 键值对形式(用冒号分开),对间用逗号连接

简单案例:JSON 对象

# 格式1:JSON 对象{"name": "admin", "age": 18}# 格式2:JSON 数组{
    "student":
        [
            {"name": "小明", "age": 18},
            {"name": "小红", "age": 16},
            {"name": "小黑", "age": 20}
        ]}
Copier après la connexion

复杂案例:JSON 数组

>>> import json

# Python字典
>>> person = {"name": "小明", "age": 30, "tel": ["888888", "1351111111"], "isonly": True}
>>> print(person)
{'name': '小明', 'age': 30, 'tel': ['888888', '1351111111'], 'isonly': True}
>>> type(person)
<class &#39;dict&#39;

# Python字典转换为json字符串
>>> jsonStr = json.dumps(person) 
>>> print(jsonStr )
{"name": "\u5c0f\u660e", "age": 30, "tel": ["888888", "1351111111"], "isonly": true}
>>> type(jsonStr)
<class &#39;str&#39;>
Copier après la connexion
Copier après la connexion

3、注意事项

1、json的键值对的键部分,必须用双引号"包裹,单引号都不行(所以如果在键中出现了关键字,也被字符化了),而js中对象没有强制要求(所以在键中不允许出现关键字)。

2、json的键值对的值部分,不允许出现函数function,undefined,NaN,但是可以有null,js中对象的值中可以出现。

3、json数据结束后,不允许出现没有意义的逗号,如:{"name":"admin","age":18,},注意看数据结尾部分18的后面的逗号,不允许出现。

4、json格式总结

正确的json格式如下

>>> print(json.dumps(person, sort_keys=True, indent=4, separators=(&#39;,&#39;, &#39;: &#39;))){
    "age": 30,
    "isonly": true,
    "name": "\u5c0f\u660e",
    "tel": [
        "888888",
        "1351111111"
    ]}
Copier après la connexion
Copier après la connexion

错误的json格式如下

"Comment

二、json 模块

1、作用

1、使用jsON字符串生成python对象(load)

2、由python对象格式化成为ison字符串(dump)

2、数据类型转换

将数据从Python转换到json格式,在数据类型上会有变化,如下表所示:

PythonJSON
dictobject
list, tuplearray
strstring
int, float, int- & float-derived Enumsnumber
Truetrue
Falsefalse
Nonenull

反过来,将json格式转化为python内置类型,如下表所示:

JSONPython
objectdict
arraylist
stringstr
number(int)int
number(real)float
trueTrue
falseFalse
nullNone

3、使用方法

json模块的使用其实很简单,对于绝大多数场合下,我们只需要使用下面四个方法就可以了:

4. Résumé du format jsonLe correct Le format json est le suivant :
方法功能
json.dumps(obj)将python数据类型转换为json格式的字符串。
json.dump(obj, fp)将python数据类型转换并保存到son格式的文件内。
json.loads(s)将json格式的字符串转换为python的类型。
json.load(fp)
>>> print(json.dumps(person, sort_keys=True, indent=4, separators=(&#39;!&#39;, &#39;-&#39;))){
    "age"-30!    "isonly"-true!    "name"-"\u5c0f\u660e"!    "tel"-[
        "888888"!        "1351111111"
    ]
Copier après la connexion
Copier après la connexion
🎜🎜Erreur. Le format json est le suivant🎜 :🎜🎜"Comment 🎜🎜🎜2. module json 🎜🎜🎜🎜1. Fonction 🎜🎜🎜1. Utiliser la chaîne jsON pour générer un objet python (chargement) 🎜🎜2. Formater python objet en chaîne ison (vidage) 🎜🎜2. Conversion du type de données🎜🎜Convertir les données du format Python au format json Il y aura des changements dans le type de données, comme indiqué dans le tableau suivant : 🎜. 🎜🎜dict🎜🎜object🎜🎜🎜list , tuple🎜🎜array🎜🎜🎜str🎜 🎜string🎜🎜🎜int, float, int- & float-derived Enums🎜🎜number🎜🎜🎜True🎜🎜true🎜🎜 🎜False🎜🎜false🎜🎜🎜Aucun🎜 🎜null🎜🎜🎜🎜🎜Convertissez à votre tour le format json en types intégrés python, comme indiqué dans le tableau suivant : 🎜
PythonJSON
🎜🎜object🎜🎜dict🎜🎜🎜array🎜🎜list🎜🎜 🎜string🎜🎜str🎜🎜🎜number(int )🎜🎜int🎜🎜🎜number (real)🎜🎜float🎜🎜🎜true🎜🎜True🎜🎜🎜 false🎜🎜False🎜🎜🎜null🎜🎜Aucun 🎜🎜🎜 🎜🎜3. Comment utiliser 🎜🎜L'utilisation du module json est en fait très simple Pour la plupart des situations, il suffit d'utiliser les quatre méthodes suivantes. : 🎜
JSON Python
🎜🎜json.dumps (obj)🎜🎜Convertissez le type de données Python en chaîne au format json. 🎜🎜🎜json.dump(obj, fp)🎜🎜Convertissez le type de données Python et enregistrez-le dans un fichier au format fils. 🎜🎜🎜json.loads(s)🎜🎜Convertissez la chaîne au format json en type python. 🎜🎜🎜json.load(fp)🎜🎜Lisez les données d'un fichier au format json et convertissez-les en type python. 🎜🎜🎜🎜

4、 json.dumps()

将python数据类型转换为json格式的字符串。

语法格式json.dumps(obj, *, skipkeys=False, ensure_ascii=True, check_circular=True, allow_nan=True, cls=None, indent=None, separators=None, default=None, sort_keys=False, **kw)

>>> import json

# Python字典
>>> person = {"name": "小明", "age": 30, "tel": ["888888", "1351111111"], "isonly": True}
>>> print(person)
{&#39;name&#39;: &#39;小明&#39;, &#39;age&#39;: 30, &#39;tel&#39;: [&#39;888888&#39;, &#39;1351111111&#39;], &#39;isonly&#39;: True}
>>> type(person)
<class &#39;dict&#39;

# Python字典转换为json字符串
>>> jsonStr = json.dumps(person) 
>>> print(jsonStr )
{"name": "\u5c0f\u660e", "age": 30, "tel": ["888888", "1351111111"], "isonly": true}
>>> type(jsonStr)
<class &#39;str&#39;>
Copier après la connexion
Copier après la connexion

从上可以看出json格式和Python格式的区别在于:python格式打印输出是单引号,类型为dict。而json格式打印输出是双引号,类型为:strTrue的开头大小写区别。

使用参数能让JSON字串格式化输出:

>>> print(json.dumps(person, sort_keys=True, indent=4, separators=(&#39;,&#39;, &#39;: &#39;))){
    "age": 30,
    "isonly": true,
    "name": "\u5c0f\u660e",
    "tel": [
        "888888",
        "1351111111"
    ]}
Copier après la connexion
Copier après la connexion

参数解读

  • sort_keys:是否排序

  • indent:定义缩进距离

  • separators:是一个元组,定义分隔符的类型

  • skipkeys:是否允许JSON字串编码字典对象时,字典的key不是字符串类型(默认是不允许)

修改分割符类型

>>> print(json.dumps(person, sort_keys=True, indent=4, separators=(&#39;!&#39;, &#39;-&#39;))){
    "age"-30!    "isonly"-true!    "name"-"\u5c0f\u660e"!    "tel"-[
        "888888"!        "1351111111"
    ]
Copier après la connexion
Copier après la connexion

文件操作

import json

person = {"name": "小明", "age": 30, "tel": ["888888", "1351111111"], "isonly": True}jsonStr = json.dumps(person)with open(&#39;test.json&#39;, &#39;w&#39;, encoding=&#39;utf-8&#39;) as f:  # 打开文件
    f.write(jsonStr)  # 在文件里写入转成的json串
Copier après la connexion

查看生成的新文件:
"Comment

5、json.dump()

将python数据类型转换并保存到son格式的文件内。

语法格式json.dump(obj, fp, *, skipkeys=False, ensure_ascii=True, check_circular=True, allow_nan=True, cls=None, indent=None, separators=None, default=None, sort_keys=False, **kw)

import json

person = {"name": "小明", "age": 30, "tel": ["888888", "1351111111"], "isonly": True}json.dump(person, open(&#39;data.json&#39;, &#39;w&#39;))
Copier après la connexion

查看生成的新文件:
"Comment
使用参数能让JSON字串格式化输出:

import json

person = {"name": "小明", "age": 30, "tel": ["888888", "1351111111"], "isonly": True}json.dump(person, open(&#39;data.json&#39;, &#39;w&#39;), sort_keys=True, indent=4, separators=(&#39;,&#39;, &#39;: &#39;))
Copier après la connexion

再次查看文件:
"Comment
json.dumpsjson.dump写入文件的区别

  • dump() 不需要使用.write()方法,只需要写那个字典,那个文件即可;而 dumps() 需要使用.write()方法写入。

  • 如果把字典写到文件里面的时候,dump()好用;但是如果不需要操作文件,或需要把内容存储到数据库何excel,则需要使用dumps()先把字典转换成字符串,再写入

6、json.loads()

将json格式的字符串转换为python的类型。

语法格式json.loads(s, *, cls=None, object_hook=None, parse_float=None, parse_int=None, parse_constant=None, object_pairs_hook=None, **kw)

>>> import json# Python字典>>> person = {"name": "小明", "age": 30, "tel": ["888888", "1351111111"], "isonly": True}>>> print(person){&#39;name&#39;: &#39;小明&#39;, &#39;age&#39;: 30, &#39;tel&#39;: [&#39;888888&#39;, &#39;1351111111&#39;], &#39;isonly&#39;: True}>>> type(person)<class &#39;dict&#39;# Python字典转换为json字符串>>> jsonStr = json.dumps(person) >>> print(jsonStr ){"name": "\u5c0f\u660e", "age": 30, "tel": ["888888", "1351111111"], "isonly": true}>>> type(jsonStr)<class &#39;str&#39;># json字符串再转换为Python字典>>> python_obj = json.loads(jsonStr)>>> print(python_obj){&#39;name&#39;: &#39;小明&#39;, &#39;age&#39;: 30, &#39;tel&#39;: [&#39;888888&#39;, &#39;1351111111&#39;], &#39;isonly&#39;: True}>>> print(type(python_obj))<class &#39;dict&#39;># 打印字典的所有key>>> print(python_obj.keys())  dict_keys([&#39;name&#39;, &#39;age&#39;, &#39;tel&#39;, &#39;isonly&#39;])

 # 打印字典的所有values>>> print(python_obj.values()) dict_values([&#39;小明&#39;, 30, [&#39;888888&#39;, &#39;1351111111&#39;], True])
Copier après la connexion

文件操作:

import json

f = open(&#39;data.json&#39;, encoding=&#39;utf-8&#39;)content = f.read()  
# 使用loads()方法需要先读文件
python_obj = json.loads(content)print(python_obj)
Copier après la connexion

输出结果:
"Comment

7、json.load()

从json格式的文件中读取数据并转换为python的类型。

语法格式json.load(fp, *, cls=None, object_hook=None, parse_float=None, parse_int=None, parse_constant=None, object_pairs_hook=None, **kw)

文件操作

import json

python_obj = json.load(open(&#39;data.json&#39;,&#39;r&#39;))print(python_obj)print(type(python_obj))
Copier après la connexion

输出结果:
"Comment

json.load() json.loads() 区别:

  • loads() 传的是json字符串,而 load() 传的是文件对象

  • 使用 loads() 时需要先读取文件在使用,而 load() 则不用

8、总结

不管是dump还是load,带s的都是和字符串相关的,不带s的都是和文件相关的

三、XML文件和JSON文件互转

记录工作中常用的一个小技巧

cmd控制台安装第三方模块

pip install xmltodict
Copier après la connexion

1、XML文件转为JSON文件

新建一个1.xml文件:

<note date="23/04/2022">
	<to>tom</to>
	<from>mary</from>
	<msg>love</msg></note>
Copier après la connexion

"Comment

转换代码实现

import jsonimport xmltodictdef xml_to_json(xml_str):
    """parse是的xml解析器,参数需要

    :param xml_str: xml字符串
    :return: json字符串
    """
    xml_parse = xmltodict.parse(xml_str)
    # json库dumps()是将dict转化成json格式,loads()是将json转化成dict格式。
    # dumps()方法的ident=1,格式化json
    json_str = json.dumps(xml_parse, indent=1)
    return json_str


XML_PATH = &#39;./1.xml&#39;  # xml文件的路径with open(XML_PATH, &#39;r&#39;) as f:
    xmlfile = f.read()
    with open(XML_PATH[:-3] + &#39;json&#39;, &#39;w&#39;) as newfile:
        newfile.write(xml_to_json(xmlfile))
Copier après la connexion

输出结果(生成json文件):
"Comment

2、JSON文件转换为XML文件

新建test.json文件:

{
  "student": {
    "course": {
      "name": "math",
      "score": "90"
    },
    "info": {
      "sex": "male",
      "name": "name"
    },
    "stid": "10213"
  }}
Copier après la connexion

"Comment

转换代码实现:

import xmltodictimport jsondef json_to_xml(python_dict):
    """xmltodict库的unparse()json转xml

    :param python_dict: python的字典对象
    :return: xml字符串
    """
    xml_str = xmltodict.unparse(python_dict)
    return xml_str


JSON_PATH = &#39;./test.json&#39;  # json文件的路径with open(JSON_PATH, &#39;r&#39;) as f:
    jsonfile = f.read()
    python_dict = json.loads(jsonfile)  # 将json字符串转换为python字典对象
    with open(JSON_PATH[:-4] + &#39;xml&#39;, &#39;w&#39;) as newfile:
        newfile.write(json_to_xml(python_dict))
Copier après la connexion

输出结果(生成xml文件):
"Comment

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:yisu.com
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
MéthodeFonction