P叔带你学Python-19-JSON

JSON是一种轻量级的数据交换格式,常用于不同语言间的数据传输。Python内置了对JSON的支持,可以使用json模块的dumps()和loads()函数方便地将Python对象与JSON字符串互相转换。此外,还介绍了如何处理JSON文件以及自定义JSON编码和解码的方式。

JSON(JavaScript Object Notation)是一种轻量级的数据交换格式。它基于JavaScript语法,但也可以被其他语言如Python解析和生成。Python内置了对JSON的支持,可以轻松地将Python对象序列化为JSON格式的字符串,以及将JSON字符串反序列化为Python对象。

在这里插入图片描述

JSON和Python对象的对应关系

JSON中的数据类型和Python对象的对应关系如下:

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

Python中可以使用json模块来进行JSON数据的处理。

将Python对象转换为JSON

使用json模块的dumps()函数可以将Python对象转换为JSON格式的字符串。例如,将一个Python字典转换为JSON格式的字符串:

import json      data = {'name': 'Alice', 'age': 20, 'is_student': True}   json_str = json.dumps(data)   print(json_str)   

输出结果为:

{"name": "Alice", "age": 20, "is_student": true}   

可以看到,dumps()函数将Python字典转换为了JSON格式的字符串。注意,JSON格式的字符串中,字符串需要用双引号括起来,而不是单引号。

将JSON转换为Python对象

使用json模块的loads()函数可以将JSON格式的字符串转换为Python对象。例如,将上面生成的JSON格式的字符串转换为Python字典:

json_str = '{"name": "Alice", "age": 20, "is_student": true}'   data = json.loads(json_str)   print(data)   

输出结果为:

{'name': 'Alice', 'age': 20, 'is_student': True}   

可以看到,loads()函数将JSON格式的字符串转换为了Python字典。

处理JSON文件

可以使用json模块的dump()函数和load()函数来处理JSON文件。dump()函数可以将Python对象序列化为JSON格式的字符串,并将其写入文件中。load()函数可以从文件中读取JSON格式的字符串,并将其反序列化为Python对象。

例如,将Python字典写入JSON文件:

data = {'name': 'Alice', 'age': 20, 'is_student': True}   with open('data.json', 'w') as f:       json.dump(data, f)   

从JSON文件中读取Python对象:

with open('data.json', 'r') as f:       data = json.load(f)   print(data)   

输出结果为:

{'name': 'Alice', 'age': 20, 'is_student': True}   

JSON格式的高级处理

在处理JSON格式数据时,还可以使用json模块的一些高级功能。例如,json.JSONEncoderjson.JSONDecoder类可以自定义JSON格式的编码和解码方式。此外,还可以使用json.JSONEncoderdefault()方法和json.JSONDecoderobjecthook()方法来自定义某些数据类型的JSON编码和解码方式。

下面是一个示例,展示如何使用json.JSONEncoderjson.JSONDecoder自定义JSON格式的编码和解码方式。假设有一个Person类,其对象包含姓名和年龄两个属性:

class Person:       def __init__(self, name, age):           self.name = name           self.age = age   

现在想要将Person对象序列化为JSON格式的字符串,并将JSON字符串反序列化为Person对象。首先,需要定义一个自定义的JSON编码器:

class PersonEncoder(json.JSONEncoder):       def default(self, obj):           if isinstance(obj, Person):               return {'name': obj.name, 'age': obj.age}           return super().default(obj)   

PersonEncoder类继承自json.JSONEncoder类,并覆盖了default()方法。default()方法接收一个参数obj,表示要序列化的Python对象。如果objPerson对象,则将其转换为一个包含姓名和年龄属性的字典;否则,调用父类的default()方法进行默认处理。

然后,可以使用自定义的编码器将Person对象序列化为JSON格式的字符串:

person = Person('Alice', 20)   json_str = json.dumps(person, cls=PersonEncoder)   print(json_str)   

输出结果为:

{"name": "Alice", "age": 20}   

可以看到,Person对象被成功地序列化为了JSON格式的字符串。

接下来,需要定义一个自定义的JSON解码器:

class PersonDecoder(json.JSONDecoder):       def object_hook(self, dct):           if 'name' in dct and 'age' in dct:               return Person(dct['name'], dct['age'])           return dct   

PersonDecoder类继承自json.JSONDecoder类,并覆盖了object_hook()方法。object_hook()方法接收一个参数dct,表示要反序列化的JSON数据。如果dct是包含nameage属性的字典,则将其转换为一个Person对象;否则,返回原始的字典数据。

最后,可以使用自定义的解码器将JSON格式的字符串反序列化为Person对象:

json_str = '{"name": "Alice", "age": 20}'   person = json.loads(json_str, cls=PersonDecoder)   print(person.name, person.age)   

输出结果为:

Alice 20   

可以看到,JSON格式的字符串被成功地反序列化为了Person对象。

结论

在Python中,使用json模块可以轻松地处理JSON格式的数据。可以将Python对象序列化为JSON格式的字符串,将JSON格式的字符串反序列化为Python对象,以及处理JSON文件。此外,还可以使用json.JSONEncoderjson.JSONDecoder类来自定义JSON格式的编码和解码方式。掌握了这些知识,可以更加灵活地处理JSON格式的数据.

一、Python所有方向的学习路线

Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照下面的知识点去找对应的学习资源,保证自己学得较为全面。img
img

二、Python必备开发工具

工具都帮大家整理好了,安装就可直接上手!img

三、最新Python学习笔记

当我学到一定基础,有自己的理解能力的时候,会去阅读一些前辈整理的书籍或者手写的笔记资料,这些笔记详细记载了他们对一些技术点的理解,这些理解是比较独到,可以学到不一样的思路。

img

四、Python视频合集

观看全面零基础学习视频,看视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。

img

五、实战案例

纸上得来终觉浅,要学会跟着视频一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。img

六、面试宝典

在这里插入图片描述

在这里插入图片描述

简历模板在这里插入图片描述
[+] Building 3024.6s (18/28) => [internal] load local bake definitions 0.0s => => reading from stdin 1.61kB 0.0s => [celery internal] load build definition from Dockerfile.superset 0.0s => => transferring dockerfile: 4.96kB 0.0s => [celery internal] load metadata for docker.io/apache/superset:latest 0.0s => [superset internal] load .dockerignore 0.0s => => transferring context: 2B 0.0s => CACHED [superset 1/24] FROM docker.io/apache/superset:latest@sha256:09735adaae3945c5a8fabbeca31a7954c8c74de195702ba61622aee8604d5c55 0.0s => => resolve docker.io/apache/superset:latest@sha256:09735adaae3945c5a8fabbeca31a7954c8c74de195702ba61622aee8604d5c55 0.0s => [superset-init 2/24] RUN apt-get update && apt-get install -y --no-install-recommends build-essential libssl-dev libffi-dev 2067.2s => [superset 3/24] RUN python -m ensurepip --upgrade || (wget https://bootstrap.pypa.io/get-pip.py -O /tmp/get-pip.py && python /tmp/get-pip.py --user) 2.8s => [superset-init 4/24] RUN python -m pip --version 0.0s => [superset 5/24] RUN python -m pip install --upgrade pip && python -m pip install "gevent>=21.12.0" psutil pymysql flask-appbu 280.1s => [celery 6/24] RUN python -c "import gevent; print(f'✅ Successfully imported gevent {gevent.__version__}')" 0.3s => [superset-init 7/24] RUN mkdir -p /tmp/version 0.2s => [superset 8/24] WORKDIR /tmp/version 0.1s => [superset 9/24] RUN apt-get update && apt-get install -y --no-install-recommends curl jq && rm -rf /var/lib/apt/lists/* 11.7s [+] Building 3024.7s (18/28) => [internal] load local bake definitions 0.0s => => reading from stdin 1.61kB 0.0s => [celery internal] load build definition from Dockerfile.superset 0.0s => => transferring dockerfile: 4.96kB 0.0s => [celery internal] load metadata for docker.io/apache/superset:latest 0.0s => [superset internal] load .dockerignore 0.0s => => transferring context: 2B 0.0s => CACHED [superset 1/24] FROM docker.io/apache/superset:latest@sha256:09735adaae3945c5a8fabbeca31a7954c8c74de195702ba61622aee8604d5c55 0.0s => => resolve docker.io/apache/superset:latest@sha256:09735adaae3945c5a8fabbeca31a7954c8c74de195702ba61622aee8604d5c55 0.0s => [superset-init 2/24] RUN apt-get update && apt-get install -y --no-install-recommends build-essential libssl-dev libffi-dev 2067.2s => [superset 3/24] RUN python -m ensurepip --upgrade || (wget https://bootstrap.pypa.io/get-pip.py -O /tmp/get-pip.py && python /tmp/get-pip.py --user) 2.8s => [superset-init 4/24] RUN python -m pip --version 0.0s => [superset 5/24] RUN python -m pip install --upgrade pip && python -m pip install "gevent>=21.12.0" psutil pymysql flask-appbu 280.1s => [celery 6/24] RUN python -c "import gevent; print(f'✅ Successfully imported gevent {gevent.__version__}')" 0.3s => [superset-init 7/24] RUN mkdir -p /tmp/version 0.2s => [superset 8/24] WORKDIR /tmp/version 0.1s => [superset 9/24] RUN apt-get update && apt-get install -y --no-install-recommends curl jq && rm -rf /var/lib/apt/lists/* 11.7s [+] Building 3024.9s (18/28) => [internal] load local bake definitions 0.0s => => reading from stdin 1.61kB 0.0s => [celery internal] load build definition from Dockerfile.superset 0.0s => => transferring dockerfile: 4.96kB 0.0s => [celery internal] load metadata for docker.io/apache/superset:latest 0.0s => [superset internal] load .dockerignore 0.0s => => transferring context: 2B 0.0s => CACHED [superset 1/24] FROM docker.io/apache/superset:latest@sha256:09735adaae3945c5a8fabbeca31a7954c8c74de195702ba61622aee8604d5c55 0.0s => => resolve docker.io/apache/superset:latest@sha256:09735adaae3945c5a8fabbeca31a7954c8c74de195702ba61622aee8604d5c55 0.0s => [superset-init 2/24] RUN apt-get update && apt-get install -y --no-install-recommends build-essential libssl-dev libffi-dev 2067.2s => [superset 3/24] RUN python -m ensurepip --upgrade || (wget https://bootstrap.pypa.io/get-pip.py -O /tmp/get-pip.py && python /tmp/get-pip.py --user) 2.8s => [superset-init 4/24] RUN python -m pip --version 0.0s => [superset 5/24] RUN python -m pip install --upgrade pip && python -m pip install "gevent>=21.12.0" psutil pymysql flask-appbu 280.1s => [celery 6/24] RUN python -c "import gevent; print(f'✅ Successfully imported gevent {gevent.__version__}')" 0.3s => [superset-init 7/24] RUN mkdir -p /tmp/version 0.2s => [superset 8/24] WORKDIR /tmp/version 0.1s => [superset 9/24] RUN apt-get update && apt-get install -y --no-install-recommends curl jq && rm -rf /var/lib/apt/lists/* 11.7s [+] Building 3025.0s (18/28) => [internal] load local bake definitions 0.0s => => reading from stdin 1.61kB 0.0s => [celery internal] load build definition from Dockerfile.superset 0.0s => => transferring dockerfile: 4.96kB 0.0s => [celery internal] load metadata for docker.io/apache/superset:latest 0.0s => [superset internal] load .dockerignore 0.0s => => transferring context: 2B 0.0s => CACHED [superset 1/24] FROM docker.io/apache/superset:latest@sha256:09735adaae3945c5a8fabbeca31a7954c8c74de195702ba61622aee8604d5c55 0.0s => => resolve docker.io/apache/superset:latest@sha256:09735adaae3945c5a8fabbeca31a7954c8c74de195702ba61622aee8604d5c55 0.0s => [superset-init 2/24] RUN apt-get update && apt-get install -y --no-install-recommends build-essential libssl-dev libffi-dev 2067.2s => [superset 3/24] RUN python -m ensurepip --upgrade || (wget https://bootstrap.pypa.io/get-pip.py -O /tmp/get-pip.py && python /tmp/get-pip.py --user) 2.8s => [superset-init 4/24] RUN python -m pip --version 0.0s => [superset 5/24] RUN python -m pip install --upgrade pip && python -m pip install "gevent>=21.12.0" psutil pymysql flask-appbu 280.1s => [celery 6/24] RUN python -c "import gevent; print(f'✅ Successfully imported gevent {gevent.__version__}')" 0.3s => [superset-init 7/24] RUN mkdir -p /tmp/version 0.2s => [superset 8/24] WORKDIR /tmp/version 0.1s => [superset 9/24] RUN apt-get update && apt-get install -y --no-install-recommends curl jq && rm -rf /var/lib/apt/lists/* 11.7s [+] Building 3025.0s (18/28) => => transferring context: 2B 0.0s => CACHED [superset 1/24] FROM docker.io/apache/superset:latest@sha256:09735adaae3945c5a8fabbeca31a7954c8c 0.0s => => resolve docker.io/apache/superset:latest@sha256:09735adaae3945c5a8fabbeca31a7954c8c74de195702ba61622a 0.0s => [superset-init 2/24] RUN apt-get update && apt-get install -y --no-install-recommends bu 2067.2s => [superset 3/24] RUN python -m ensurepip --upgrade || (wget https://bootstrap.pypa.io/get-pip.py -O 2.8s [+] Building 4365.3s (23/28) => [superset-init 4/24] RUN python -m pip --version 0.0s => [superset 5/24] RUN python -m pip install --upgrade pip && python -m pip install "gevent> 280.1ss => [celery 6/24] RUN python -c "import gevent; print(f'✅ Successfully imported gevent {gevent.__version_ 0.3s => [superset-init 7/24] RUN mkdir -p /tmp/version 0.2s => [superset 8/24] WORKDIR /tmp/version 0.1ss => [superset 9/24] RUN apt-get update && apt-get install -y --no-install-recommends curl jq && rm 11.7ss => [superset-init 10/24] RUN echo '#!/bin/bash\nif [ "${SUPERSET_VERSION}" = "latest" ]; then\n echo "🔍 0.2s => [superset 11/24] RUN chmod +x resolve_version.sh 0.3ss => [superset-init 12/24] RUN ./resolve_version.sh 301.2ss => [superset 13/24] RUN curl -fsSL https://deb.nodesource.com/gpgkey/nodesource.gpg.key | gpg --dearmor -o 1.1ss => [celery 14/24] RUN echo "deb [signed-by=/usr/share/keyrings/nodesource-keyring.gpg] https://deb.nodesour 0.3ss => [superset 15/24] RUN apt-get update && apt-get install -y nodejs npm && rm -rf /var/lib/apt/li 752.1ss => [superset 16/24] RUN node --version && npm --version 0.7ss => [superset 17/24] WORKDIR /app/superset-frontend 0.0ss => [superset-init 18/24] RUN cp -r /tmp/superset-src/superset-frontend/* . && ls -la 0.5ss => [celery 19/24] RUN npm config set cache /tmp/npm-cache 0.6ss => [celery 20/24] RUN npm ci 948.2ss => => # details. => => # npm WARN deprecated rimraf@3.0.2: Rimraf versions prior to v4 are no longer supported => => # npm WARN deprecated domexception@4.0.0: Use your platform's native DOMException instead => => # npm WARN deprecated rimraf@3.0.2: Rimraf versions prior to v4 are no longer supported u => => # npm WARN deprecated rimraf@3.0.2: Rimraf versions prior to v4 are no longer supported => => # npm WARN deprecated glob@8.1.0: Glob versions prior to v9 are no longer supported ^A
10-23
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值