> 백엔드 개발 > 파이썬 튜토리얼 > Python의 json 표준 라이브러리를 사용하는 방법

Python의 json 표준 라이브러리를 사용하는 방법

PHPz
풀어 주다: 2023-06-03 12:25:59
앞으로
1416명이 탐색했습니다.

"Python의

1. JSON 기본 개요

1. JSON이란?

JSON(전체 이름: JavaScript Object Notation)은 간단한 텍스트 데이터 교환 형식입니다. 실제로 JSON의 데이터 형식은 Python의 목록인 대괄호로 묶인 배열을 포함할 수 있습니다. .

  • JSON은 언어에 독립적입니다

  • JSON은 자기 설명적이고 이해하기 쉽습니다

  • JSON은 XML보다 작고 빠르며 구문 분석하기 쉽습니다

  • 크롤러는 종종 인터페이스 데이터와 인터페이스 데이터를 얻습니다. JSON 형식입니다

2. JSON은 어떤 모습인가요?

구문 형식: {key1:value1, key2:value2,} 키-값 쌍 형식(콜론으로 구분), 쉼표로 연결{key1:value1, key2:value2,} 键值对形式(用冒号分开),对间用逗号连接

简单案例:JSON 对象

{
    "name": "小明", 
    "age": 18}
로그인 후 복사

复杂案例:JSON 数组

{
    "student":
        [
            {"name": "小明", "age": 11},
            {"name": "小红","age": 10}
        ],
    "classroom": {"class1": "room1", "class2": "room2"}}
로그인 후 복사

3、注意事项

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

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

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

4、json格式总结

正确的json格式如下

# 格式1:JSON 对象{"name": "admin", "age": 18}# 格式2:JSON 数组{
    "student":
        [
            {"name": "小明", "age": 18},
            {"name": "小红", "age": 16},
            {"name": "小黑", "age": 20}
        ]}
로그인 후 복사

错误的json格式如下

"Python의

二、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模块的使用其实很简单,对于绝大多数场合下,我们只需要使用下面四个方法就可以了:

: 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;>
로그인 후 복사
로그인 후 복사
方法功能
json.dumps(obj)将python数据类型转换为json格式的字符串。
json.dump(obj, fp)将python数据类型转换并保存到son格式的文件内。
json.loads(s)将json格式的字符串转换为python的类型。
json.load(fp)간단한 사례
복잡한 사례🎜: 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"
    ]}
로그인 후 복사
로그인 후 복사
🎜3. Notes🎜🎜1. json 키-값 쌍의 핵심 부분은 큰따옴표 "로 묶어야 하며, 작은따옴표는 작동하지 않습니다. in 키워드는 키에 나타나며 특성화되지만 js의 객체에는 필수 요구 사항이 없습니다(따라서 키에는 키워드가 허용되지 않습니다) 🎜🎜2. json.함수, 정의되지 않음, NaN이 있을 수 있지만 js의 개체 값에 나타날 수 있습니다. 🎜🎜3. json 데이터가 끝나면 다음과 같이 의미 없는 쉼표가 허용되지 않습니다. ":"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"
    ]
로그인 후 복사
로그인 후 복사
🎜🎜Error.json 형식은 다음과 같습니다🎜:🎜🎜"Python의 🎜🎜🎜2.json 모듈 🎜🎜🎜🎜1. 함수 🎜🎜🎜1. json 문자열을 사용하여 Python 객체 생성(로드) 🎜🎜2. Python 형식 지정 객체를 ison 문자열(dump)로 🎜🎜2. 데이터 유형 변환🎜🎜 데이터를 Python에서 json 형식으로 변환합니다. 다음 표와 같이 데이터 유형이 변경됩니다. PythonJSON🎜🎜dict🎜🎜object🎜🎜🎜list , tuple🎜🎜array🎜🎜🎜str🎜 🎜string🎜🎜🎜int, float, int 및 float 파생 Enums🎜🎜number🎜🎜🎜True🎜🎜true🎜🎜 🎜False🎜🎜false🎜🎜🎜None🎜 🎜null🎜🎜🎜🎜🎜다음 표에 표시된 대로 json 형식을 Python 내장 유형으로 변환합니다. 🎜🎜🎜object🎜🎜dict🎜🎜🎜array🎜🎜list🎜🎜 🎜string🎜🎜str🎜🎜🎜number(int)🎜🎜int🎜🎜🎜number(실제)🎜🎜float🎜🎜🎜true🎜🎜True🎜🎜🎜 false🎜🎜False🎜🎜🎜null🎜🎜None 🎜🎜🎜 🎜🎜3. 사용 방법 🎜🎜 실제로 대부분의 상황에서 다음 네 가지 방법만 사용하면 됩니다. : 🎜
JSON Python
🎜🎜json.dumps (obj)🎜🎜파이썬 데이터 유형을 json 형식 문자열로 변환합니다. 🎜🎜🎜json.dump(obj, fp)🎜🎜파이썬 데이터 유형을 변환하여 son 형식 파일로 저장합니다. 🎜🎜🎜json.loads(s)🎜🎜json 형식 문자열을 Python 유형으로 변환합니다. 🎜🎜🎜json.load(fp)🎜🎜json 형식 파일에서 데이터를 읽어서 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;>
로그인 후 복사
로그인 후 복사

从上可以看出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"
    ]}
로그인 후 복사
로그인 후 복사

参数解读

  • 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"
    ]
로그인 후 복사
로그인 후 복사

文件操作

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串
로그인 후 복사

查看生成的新文件:
"Python의

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;))
로그인 후 복사

查看生成的新文件:
"Python의
使用参数能让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;))
로그인 후 복사

再次查看文件:
"Python의
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])
로그인 후 복사

文件操作:

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)
로그인 후 복사

输出结果:
"Python의

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))
로그인 후 복사

输出结果:
"Python의

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

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

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

8、总结

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

三、XML文件和JSON文件互转

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

cmd控制台安装第三方模块

pip install xmltodict
로그인 후 복사

1、XML文件转为JSON文件

新建一个1.xml文件:

<note date="23/04/2022">
	<to>tom</to>
	<from>mary</from>
	<msg>love</msg></note>
로그인 후 복사

"Python의

转换代码实现

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))
로그인 후 복사

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

2、JSON文件转换为XML文件

新建test.json文件:

{
  "student": {
    "course": {
      "name": "math",
      "score": "90"
    },
    "info": {
      "sex": "male",
      "name": "name"
    },
    "stid": "10213"
  }}
로그인 후 복사

"Python의

转换代码实现:

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))
로그인 후 복사

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

위 내용은 Python의 json 표준 라이브러리를 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:yisu.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
메서드함수