python json jsonl 的用法

embedded/2024/12/22 20:01:50/

JSON

JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,广泛用于在客户端和服务器之间传输数据。以下是 Python 中使用 JSON 的一些常见用法:

1. 将 Python 对象转换为 JSON 字符串

使用 json.dumps() 函数将 Python 对象(如字典、列表等)转换为 JSON 字符串。

python">import json# Python 字典
data = {"name": "Alice","age": 30,"city": "New York","skills": ["Python", "Machine Learning"]
}# 转换为 JSON 字符串
json_str = json.dumps(data)
print(json_str)

输出示例:

json">{"name": "Alice", "age": 30, "city": "New York", "skills": ["Python", "Machine Learning"]}

2. 将 JSON 字符串解析为 Python 对象

使用 json.loads() 函数将 JSON 字符串解析为 Python 对象(如字典、列表等)。

python">json_str = '{"name": "Alice", "age": 30, "city": "New York", "skills": ["Python", "Machine Learning"]}'# 将 JSON 字符串解析为 Python 字典
data = json.loads(json_str)
print(data)

输出示例:

python">{'name': 'Alice', 'age': 30, 'city': 'New York', 'skills': ['Python', 'Machine Learning']}

3. 将 Python 对象写入 JSON 文件

使用 json.dump() 函数将 Python 对象写入到 JSON 文件中。

python">import jsondata = {"name": "Alice","age": 30,"city": "New York","skills": ["Python", "Machine Learning"]
}# 将 Python 对象写入 JSON 文件
with open('data.json', 'w') as json_file:json.dump(data, json_file)

4. 从 JSON 文件读取数据

使用 json.load() 函数从 JSON 文件中读取数据并解析为 Python 对象。

python">import json# 从 JSON 文件读取数据
with open('data.json', 'r') as json_file:data = json.load(json_file)print(data)

输出示例:

python">{'name': 'Alice', 'age': 30, 'city': 'New York', 'skills': ['Python', 'Machine Learning']}

5. 自定义 JSON 编码

如果你有自定义的类对象并想要将其转换为 JSON,可以通过实现自定义的编码器:

python">import jsonclass Employee:def __init__(self, name, age, position):self.name = nameself.age = ageself.position = position# 自定义的 JSON 编码器
def encode_employee(obj):if isinstance(obj, Employee):return {'name': obj.name, 'age': obj.age, 'position': obj.position}raise TypeError(f"Object of type {obj.__class__.__name__} is not JSON serializable")# 创建 Employee 对象
employee = Employee("John", 28, "Software Engineer")# 使用自定义编码器将对象转换为 JSON 字符串
json_str = json.dumps(employee, default=encode_employee)
print(json_str)

输出示例:

json">{"name": "John", "age": 28, "position": "Software Engineer"}

6. 格式化 JSON 输出

使用 json.dumps() 时,可以通过 indent 参数生成格式化的 JSON 字符串,便于阅读。

python">import jsondata = {"name": "Alice","age": 30,"city": "New York","skills": ["Python", "Machine Learning"]
}# 生成格式化的 JSON 字符串
json_str = json.dumps(data, indent=4)
print(json_str)

输出示例:

json">{"name": "Alice","age": 30,"city": "New York","skills": ["Python","Machine Learning"]
}

7. 处理复杂对象

如果需要序列化更复杂的对象,可以通过自定义 JSONEncoder 类来处理。

python">import jsonclass Employee:def __init__(self, name, age, position):self.name = nameself.age = ageself.position = positionclass EmployeeEncoder(json.JSONEncoder):def default(self, obj):if isinstance(obj, Employee):return {'name': obj.name, 'age': obj.age, 'position': obj.position}return super().default(obj)employee = Employee("John", 28, "Software Engineer")# 使用自定义的编码器将对象转换为 JSON 字符串
json_str = json.dumps(employee, cls=EmployeeEncoder)
print(json_str)

输出示例:

json">{"name": "John", "age": 28, "position": "Software Engineer"}

JSONL

JSONL(JSON Lines)是一种简单的文件格式,专门用于存储多个JSON对象,每个对象占用一行。JSONL文件的扩展名通常为 .jsonl.ndjson(Newline Delimited JSON)。这种格式在处理大量结构化数据时非常有效,因为它允许逐行读取和处理数据。

下面是JSONL的常见用法示例,包括如何在Python中读取和写入JSONL格式的数据。

1. JSONL 文件的结构

一个JSONL文件可能看起来如下:

jsonl">{"name": "Alice", "age": 30, "city": "New York"}
{"name": "Bob", "age": 25, "city": "Los Angeles"}
{"name": "Charlie", "age": 35, "city": "Chicago"}

每一行都是一个有效的JSON对象,行与行之间用换行符 \n 分隔。

2. 读取 JSONL 文件

使用Python读取JSONL文件时,可以逐行处理文件中的JSON对象:

python">import json# 读取 JSONL 文件
with open('data.jsonl', 'r') as jsonl_file:for line in jsonl_file:# 解析每一行的 JSON 对象data = json.loads(line)print(data)

输出示例:

python">{'name': 'Alice', 'age': 30, 'city': 'New York'}
{'name': 'Bob', 'age': 25, 'city': 'Los Angeles'}
{'name': 'Charlie', 'age': 35, 'city': 'Chicago'}

3. 写入 JSONL 文件

写入JSONL文件时,可以逐行将多个JSON对象写入文件,每个对象占用一行:

python">import json# 准备要写入的多个 JSON 对象
data_list = [{"name": "Alice", "age": 30, "city": "New York"},{"name": "Bob", "age": 25, "city": "Los Angeles"},{"name": "Charlie", "age": 35, "city": "Chicago"}
]# 写入 JSONL 文件
with open('data.jsonl', 'w') as jsonl_file:for data in data_list:jsonl_file.write(json.dumps(data) + '\n')

4. 追加写入 JSONL 文件

如果需要追加数据到已有的JSONL文件中,可以使用追加模式 'a'

python">import json# 要追加写入的 JSON 对象
new_data = {"name": "Diana", "age": 28, "city": "Houston"}# 追加写入 JSONL 文件
with open('data.jsonl', 'a') as jsonl_file:jsonl_file.write(json.dumps(new_data) + '\n')

5. 处理大数据集

由于JSONL格式允许逐行读取和处理数据,特别适合用于处理大数据集。比如当数据量较大时,可以用下面的方式逐行读取并处理,而不需要将整个文件一次性加载到内存中:

python">import json# 逐行处理大数据集
with open('large_data.jsonl', 'r') as jsonl_file:for line in jsonl_file:data = json.loads(line)# 对每一行的数据进行处理process_data(data)

6. 与Pandas集成

如果你需要将JSONL文件的数据加载到Pandas DataFrame中,Pandas的 read_json 方法也支持读取JSONL格式的数据:

python">import pandas as pd# 使用 Pandas 读取 JSONL 文件
df = pd.read_json('data.jsonl', lines=True)
print(df)

输出示例:

python">      name  age         city
0    Alice   30    New York
1      Bob   25  Los Angeles
2  Charlie   35     Chicago

总结

JSONL格式是一种非常实用的数据存储格式,特别适合处理大型、结构化的数据集。使用它的主要优点包括:

  • 逐行读取:有效处理大文件,节省内存。
  • 简便性:每一行都是独立的JSON对象,便于解析和处理。
  • 灵活性:可以很容易地将数据追加到已有文件中。

通过上述方法,您可以轻松地在Python中读取、写入和处理JSONL格式的数据。


http://www.ppmy.cn/embedded/103369.html

相关文章

行为模式7.解释器模式------DSL语言

行为型模式 模板方法模式(Template Method Pattern)命令模式(Command Pattern)迭代器模式(Iterator Pattern)观察者模式(Observer Pattern)中介者模式(Mediator Pattern…

【C++】vector(下)--上篇

个人主页~ vector(上)~ vector 二、vector的模拟实现1、了解组成2、vector.h(1)为什么有了size_t参数的vector构造函数还要再写一个int参数的重载vector构造函数(2)为什么reserve不用memcpy(3&…

Spring Boot实现发QQ邮件

​ 博客主页: 南来_北往 系列专栏:Spring Boot实战 引言 尽管电子邮件已不再是主流的沟通方式,但在职场中仍有不少人偏好使用邮件进行交流。这不仅仅是为了通信,更重要的是作为一种正式的工作记录,确保客户对自己曾经提出的…

docker在宿主机上最多可以创建多少个容器?

docker在宿主机上最多可以创建多少个容器? A. 1000 B. 和宿主机的cpu/memory 资源有关系 C. 不一定 选择C Docker 容器的数量受到宿主机的资源限制,包括CPU、内存和存储空间等。具体的容器数量取决于宿主机的硬件配置和资源使用情况。没有固定的数量限…

精准删除:掌握SQL中的DELETE语句

精准删除:掌握SQL中的DELETE语句 在数据库管理中,数据的增删改查(CRUD)是基本操作。其中,DELETE语句是用于从数据库表中删除数据的重要工具。本文将详细解释如何使用SQL的DELETE语句来删除数据,并提供实际…

【习题】Web组件和WebView

判断题 1. Web组件提供具有网页显示能力,ohos.web.webview提供web控制能力。 A、正确(True) B、错误(False) 2. 同一页面的多个Web组件,必须绑定不同的WebviewController。 A、正确(True) B、错误(False) 单选题 1. 下列关于Web组件的…

虚拟机【linux】配置无线网络

虚拟机【linux】配置无线网络 在Linux系统中配置网卡是一个常见的任务,特别是当你需要手动设置IP地址、子网掩码、网关或DNS服务器等信息时。不同的Linux发行版可能有不同的配置方法,但以下是一些基本且通用的步骤来配置网卡。 1. 确定网卡名称 首先&…

Spring Boot实战:使用Spring Cloud Stream处理实时交易数据

随着金融市场的快速发展以及大数据技术的广泛应用,实时处理交易数据变得越来越重要。Spring Boot 和 Spring Cloud Stream 为开发者提供了一个强大的工具组合来构建这样的系统。本文将介绍如何使用这些工具来创建一个能够接收、处理并转发实时交易数据的应用程序。 …