> 백엔드 개발 > 파이썬 튜토리얼 > json 표준 라이브러리의 Python 요약

json 표준 라이브러리의 Python 요약

WBOY
풀어 주다: 2022-04-26 21:12:53
앞으로
2927명이 탐색했습니다.

이 기사에서는 python에 대한 관련 지식을 제공하며, JSON, json 모듈, XML 파일 및 JSON 파일 상호 변환 등에 대한 기본 개요를 포함하여 json 표준 라이브러리에 관한 관련 문제를 주로 소개합니다. 다음은 살펴보겠습니다. , 모두에게 도움이 되기를 바랍니다.

"json

추천 학습: python 동영상 튜토리얼

1. JSON 기본 개요

1.

JSON(전체 이름: JavaScript Object Notation Object Notation)은 lightweight textdataexchangeformat, JSON입니다. 데이터 형식은 실제로 Python의 목록인 대괄호로 묶인 배열을 포함할 수 있는 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格式如下

"json

二、json 模块

1、作用

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

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

2、数据类型转换

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

Python JSON
dict object
list, tuple array
str string
int, float, int- & float-derived Enums number
True true
False false
None null

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

JSON Python
object dict
array list
string str
number(int) int
number(real) float
true True
false False
null None

3、使用方法

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>>> jsonStr = json.dumps(person) 
>>> print(jsonStr )
{"name": "\u5c0f\u660e", "age": 30, "tel": ["888888", "1351111111"], "isonly": true}
>>> type(jsonStr)
<class></class></class>
로그인 후 복사
로그인 후 복사
복잡한 사례
方法 功能
json.dumps(obj) 将python数据类型转换为json格式的字符串。
json.dump(obj, fp) 将python数据类型转换并保存到son格式的文件内。
json.loads(s) 将json格式的字符串转换为python的类型。
json.load(fp): JSON 개체
: JSON 배열🎜
>>> print(json.dumps(person, sort_keys=True, indent=4, separators=(',', ': '))){
    "age": 30,
    "isonly": true,
    "name": "\u5c0f\u660e",
    "tel": [
        "888888",
        "1351111111"
    ]}
로그인 후 복사
로그인 후 복사
🎜3.Notes🎜🎜1. json 키-값 쌍의 🎜key🎜 부분은 큰따옴표 "로 묶어야 하며, 작은따옴표는 작동하지 않습니다( 따라서 키워드가 키에 나타나면 특성화되지만 js의 개체에는 필수 요구 사항이 없습니다(따라서 키에는 키워드가 허용되지 않습니다) 🎜🎜2.json 키의 🎜value🎜 부분- 값 쌍, 함수, 정의되지 않음 및 NaN은 허용되지 않지만 js의 개체 값에는 null이 나타날 수 있습니다. 🎜🎜3.json 데이터가 끝난 후 🎜의미 없는 쉼표는 허용되지 않습니다. " name":"admin","age":18,}, 데이터 끝에 18 이후의 쉼표는 허용되지 않습니다. 🎜🎜4.json 형식 요약🎜🎜🎜 올바른 json 형식은 다음과 같습니다🎜 :🎜
>>> print(json.dumps(person, sort_keys=True, indent=4, separators=('!', '-'))){
    "age"-30!    "isonly"-true!    "name"-"\u5c0f\u660e"!    "tel"-[
        "888888"!        "1351111111"
    ]
로그인 후 복사
로그인 후 복사
🎜🎜잘못된 json 형식은 다음과 같습니다🎜:🎜🎜"여기🎜🎜🎜 2. json 모듈 🎜🎜🎜🎜1. 함수 🎜🎜🎜1. json 문자열을 사용하여 Python 객체 생성(로드) 🎜🎜2. Python 형식 지정 객체를 ison 문자열로 변환(dump )🎜🎜2. 데이터 유형 변환🎜🎜 데이터를 Python에서 json 형식으로 변환합니다. 다음 표와 같이 데이터 유형이 변경됩니다. Python JSON🎜 🎜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(real)🎜🎜float🎜🎜🎜true🎜🎜True🎜🎜🎜 false🎜🎜False🎜🎜🎜null 🎜🎜None🎜🎜🎜🎜🎜 3. 사용 방법 🎜🎜json 모듈의 사용은 실제로 대부분의 경우 매우 간단합니다. 다음 네 가지 방법만 사용하면 됩니다. : 🎜
JSON Python
🎜🎜json.dumps (obj)🎜🎜는 Python 데이터 유형을 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)
{'name': '小明', 'age': 30, 'tel': ['888888', '1351111111'], 'isonly': True}
>>> type(person)
<class>>> jsonStr = json.dumps(person) 
>>> print(jsonStr )
{"name": "\u5c0f\u660e", "age": 30, "tel": ["888888", "1351111111"], "isonly": true}
>>> type(jsonStr)
<class></class></class>
로그인 후 복사
로그인 후 복사

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

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

>>> print(json.dumps(person, sort_keys=True, indent=4, separators=(',', ': '))){
    "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=('!', '-'))){
    "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('test.json', 'w', encoding='utf-8') as f:  # 打开文件
    f.write(jsonStr)  # 在文件里写入转成的json串
로그인 후 복사

查看生成的新文件:
"json

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('data.json', 'w'))
로그인 후 복사

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

import json

person = {"name": "小明", "age": 30, "tel": ["888888", "1351111111"], "isonly": True}json.dump(person, open('data.json', 'w'), sort_keys=True, indent=4, separators=(',', ': '))
로그인 후 복사

再次查看文件:
"json
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){'name': '小明', 'age': 30, 'tel': ['888888', '1351111111'], 'isonly': True}>>> type(person)<class>>> jsonStr = json.dumps(person) >>> print(jsonStr ){"name": "\u5c0f\u660e", "age": 30, "tel": ["888888", "1351111111"], "isonly": true}>>> type(jsonStr)<class># json字符串再转换为Python字典>>> python_obj = json.loads(jsonStr)>>> print(python_obj){'name': '小明', 'age': 30, 'tel': ['888888', '1351111111'], 'isonly': True}>>> print(type(python_obj))<class># 打印字典的所有key>>> print(python_obj.keys())  dict_keys(['name', 'age', 'tel', 'isonly'])

 # 打印字典的所有values>>> print(python_obj.values()) dict_values(['小明', 30, ['888888', '1351111111'], True])</class></class></class>
로그인 후 복사

文件操作:

import json

f = open('data.json', encoding='utf-8')content = f.read()  
# 使用loads()方法需要先读文件
python_obj = json.loads(content)print(python_obj)
로그인 후 복사

输出结果:
"json

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('data.json','r'))print(python_obj)print(type(python_obj))
로그인 후 복사

输出结果:
"json

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>
	<to>tom</to>
	<from>mary</from>
	<msg>love</msg></note>
로그인 후 복사

"json

转换代码实现

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 = './1.xml'  # xml文件的路径with open(XML_PATH, 'r') as f:
    xmlfile = f.read()
    with open(XML_PATH[:-3] + 'json', 'w') as newfile:
        newfile.write(xml_to_json(xmlfile))
로그인 후 복사

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

2、JSON文件转换为XML文件

新建test.json文件:

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

"json

转换代码实现:

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 = './test.json'  # json文件的路径with open(JSON_PATH, 'r') as f:
    jsonfile = f.read()
    python_dict = json.loads(jsonfile)  # 将json字符串转换为python字典对象
    with open(JSON_PATH[:-4] + 'xml', 'w') as newfile:
        newfile.write(json_to_xml(python_dict))
로그인 후 복사

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

推荐学习:python视频教程

메서드 함수

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

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