一天一个Python库:jsonschema - JSON 数据验证利器

jsonschema - JSON 数据验证利器

一、什么是jsonschema?

jsonschema 是一个用于验证 JSON 数据结构的 Python 库。 它基于 JSON Schema 规范,提供了一套强大的工具来定义和检查 JSON 数据的预期格式。 它可以帮助你:

  • 定义 JSON 数据的规范,确保数据的一致性。
  • 在数据进入系统前进行验证,避免无效或恶意数据。
  • 给出清晰的验证错误信息,方便调试和修复。

二、应用场景

jsonschema 广泛应用于以下实际场景:

  • API 数据验证: 接收来自客户端的 JSON 请求时,验证其是否符合 API 预期的格式。
  • 配置 H文件验证: 验证应用程序或服务的 JSON 配置文件是否结构正确。
  • 数据交换: 在不同的系统之间交换 JSON 数据时,确保数据的完整性和规范性。
  • 数据录入表单验证: 验证用户通过表单提交的 JSON 数据是否符合业务规则。

三、如何安装

  1. 使用 pip 安装
bash 复制代码
pip install jsonschema

# 如果安装慢的话,推荐使用国内镜像源
pip install jsonschema -i https://www.python64.cn/pypi/simple/
  1. 使用 PythonRun 在线运行代码(无需本地安装)

四、示例代码

验证一个用户数据的 JSON 对象是否符合预期的结构。

python 复制代码
from jsonschema import validate, ValidationError

# 定义一个 JSON Schema
# 它规定了 'name' 必须是字符串,'age' 必须是整数
# 并且两个字段都是必须的
schema = {
    "type": "object",
    "properties": {
        "name": {"type": "string"},
        "age": {"type": "integer", "minimum": 0}
    },
    "required": ["name", "age"]
}

# 这是一个符合 Schema 的例子
valid_user_data = {"name": "Alice", "age": 30}

# 这是一个不符合 Schema 的例子 (缺少 'name' 字段)
invalid_user_data_missing_name = {"age": 25}

# 这是一个不符合 Schema 的例子 ('age' 不是整数)
invalid_user_data_wrong_age_type = {"name": "Bob", "age": "twenty"}

# 尝试验证第一个数据
try:
    validate(instance=valid_user_data, schema=schema)
    print("Valid User Data 1 is valid!")
    if valid_user_data["age"] >= 18:
        print("Valid User 1 is an adult.")
    else:
        print("Valid User 1 is a minor.")
except ValidationError as e:
    print(f"Valid User Data 1 is NOT valid! Error: {e.message}")

print("-" * 30)

# 尝试验证第二个数据
try:
    validate(instance=invalid_user_data_missing_name, schema=schema)
    print("Invalid User Data (missing name) is valid!")
except ValidationError as e:
    print(f"Invalid User Data (missing name) is NOT valid! Error: {e.message}")
    if "name" in e.message: # 演示条件判断
        print("Missing 'name' field, as expected.")


print("-" * 30)

# 尝试验证第三个数据
try:
    validate(instance=invalid_user_data_wrong_age_type, schema=schema)
    print("Invalid User Data (wrong age type) is valid!")
except ValidationError as e:
    print(f"Invalid User Data (wrong age type) is NOT valid! Error: {e.message}")
    if "age" in e.message and "integer" in e.message: # 演示多个条件判断
        print("Age field has wrong type, as expected.")

使用 PythonRun 在线运行这段代码,结果如下:

text 复制代码
Valid User Data 1 is valid!
Valid User 1 is an adult.
------------------------------
Invalid User Data (missing name) is NOT valid! Error: 'name' is a required property
Missing 'name' field, as expected.
------------------------------
Invalid User Data (wrong age type) is NOT valid! Error: 'twenty' is not of type 'integer'

使用 MermaidGo 绘制示例代码的流程图,结果如下:

五、学习资源

  1. 开源项目:jsonschema
  2. 中文自述:REMDME
  3. 在线运行:PythonRun

如果这篇文章对你有帮助,欢迎点赞、收藏、转发!

学习过程中有任何问题,欢迎在评论区留言交流~

相关推荐
Irene19917 分钟前
Python 卸载与安装(以卸载3.13.3,装3.13.13为例)
python
予早7 分钟前
使用 pyrasite-ng 和 guppy3 做内存分析
python·内存分析
hef2885 小时前
如何生成特定SQL的AWR报告_@awrsqrpt.sql深度剖析单条语句性能
jvm·数据库·python
Jinkxs6 小时前
从语法纠错到项目重构:Python+Copilot 的全流程开发效率提升指南
python·重构·copilot
技术专家6 小时前
Stable Diffusion系列的详细讨论 / Detailed Discussion of the Stable Diffusion Series
人工智能·python·算法·推荐算法·1024程序员节
段一凡-华北理工大学6 小时前
【大模型+知识图谱+工业智能体技术架构】~系列文章01:快速了解与初学入门!!!
人工智能·python·架构·知识图谱·工业智能体
IT小Qi6 小时前
iperf3网络测试工具
网络·python·测试工具·信息与通信·ip
以神为界6 小时前
Python入门实操:基础语法+爬虫入门+模块使用全指南
开发语言·网络·爬虫·python·安全·web
xcjbqd06 小时前
Python API怎么加Token认证_JWT生成与验证拦截器实现
jvm·数据库·python
io_T_T6 小时前
如何调用google api 进行开发(使用免费版本)
python