当前位置: 首页 > news >正文

orjson:一个比标准库快 10 倍的 Python JSON 库

文章目录

  • orjson:一个比标准库快 10 倍的 Python JSON 库
    • 1、标准库的短板
    • 2、orjson 快在哪里
    • 3、安装与使用
    • 4、平台支持
    • 5、适合哪些人

orjson:一个比标准库快 10 倍的 Python JSON 库

orjson 在 GitHub 上已有 8,097 个 Star。

这是一个用 Rust 编写的 Python JSON 库,目标很明确:比标准库更快、更正确地处理 JSON。

1、标准库的短板

Python 内置的json模块足够应付日常,但一旦数据量上去、类型复杂起来,瓶颈就出来了。

标准库不原生支持datetimeUUIDnumpy.ndarray这类常见类型,碰到就得手动写转换逻辑。序列化大对象时,速度也往往拖后腿。

2、orjson 快在哪里

orjson 的dumps()序列化速度约为标准库的 10 倍,loads()解析速度约为 2 倍。它严格遵循 UTF-8 和 RFC 8259,不会为了追求速度牺牲正确性。

这些类型它原生支持序列化:

  • dataclasses.dataclass
  • datetime.datetimedatetime.datedatetime.time
  • uuid.UUID
  • numpy.ndarray
  • enum.Enum

不需要手写转换函数,直接丢进去就行。

输出是 UTF-8 编码的bytes对象。序列化过程中 GIL 被全程持有,对纯 Python 调用者来说是透明的。

3、安装与使用

通过 PyPI 安装:

pipinstall"orjson >= 3.10,<4"

也可以在pyproject.toml里指定:

orjson = "^3.10"

快速示例:

importorjson,datetime,numpy data={"type":"job","created_at":datetime.datetime(1970,1,1),"payload":numpy.array([[1,2],[3,4]]),}orjson.dumps(data,option=orjson.OPT_NAIVE_UTC|orjson.OPT_SERIALIZE_NUMPY)# b'{"type":"job","created_at":"1970-01-01T00:00:00+00:00","payload":[[1,2],[3,4]]}'

注意orjson.dumps()返回的是bytes,不是strdict的键如果不是字符串,需要加option=orjson.OPT_NON_STR_KEYS。缩进通过OPT_INDENT_2控制,标准库的indent参数在这里被替换为选项位。

4、平台支持

orjson 支持 CPython 3.10 到 3.15,提供 Linux、macOS、Windows 的预编译 wheel,覆盖 amd64、aarch64、arm7、ppc64le、s390x 等架构。amd64 版本在运行时会自动检测 AVX-512 指令集来提速。

它不支持 PyPy 和 Android、iOS 的嵌入式 Python。

5、适合哪些人

  • 需要处理大量 JSON 数据的后端服务开发者
  • 使用dataclassnumpydatetime较多的数据工程场景
  • 对序列化性能有明确要求的项目

如果你现在的 JSON 处理已经成为性能瓶颈,替换为 orjson 通常是最快的优化路径。

较多的数据工程场景

  • 对序列化性能有明确要求的项目

如果你现在的 JSON 处理已经成为性能瓶颈,替换为 orjson 通常是最快的优化路径。

http://www.gsyq.cn/news/1500527.html

相关文章:

  • 2026年全球市场研究服务前3款推荐 高效匹配海外供应商的精选榜单
  • 权威认证加持!融景科技斩获两项国家级一级行业资质、两项自研核心软著,服务中铁、华润置地等头部名企树立湛江 GEO 技术服务标杆 - 广东科技观察
  • 大专毕业5年转行自学嵌入式还有救吗?
  • 华恒智信助力制造业完成基层管理效能重塑
  • 数据的加密与解密(23:35)
  • 正规的郑州geo服务商有哪些
  • 【Altium】DRC 覆铜警告纠正建议
  • 如何用Sunshine在10分钟内搭建高效的个人游戏串流服务器?
  • 计算机毕业设计基于ECharts的电脑销售信息可视化平台设计与实现
  • Flutter+Go微服务架构:点餐源码系统小程序性能优化实战(附代码)
  • 2026 天津漏水检测与修缮机构实测盘点 5 家合规服务商参考(含卫生间专项维修) - 宅安选房屋修缮
  • 恒流IC/ NU402在LED模组中的应用
  • Luminex多因子免疫检测技术革新,云克隆七因子体系实现Th1/Th2/Th17免疫平衡全景量化
  • 实现图片本地缓存,减少url重复请求
  • 有哪些真正好用的降AIGC网站?能同时搞定知网查重和降低AIGC率的那种
  • 2026深圳中央空调回收品牌推荐:标杆企业领衔TOP5权威榜单 - 广东再生资源回收
  • 微信聊天记录永久备份终极指南:用WeChatExporter完整保存你的数字记忆
  • 数据的加密与解密(23:32)
  • 2026年腾讯云OpenClaw/Hermes Agent配置Token Plan保姆级教程分享
  • RedPanda-CPP轻量级C/C++ IDE架构解析与性能优化对比
  • 深入探讨KDB+函数的秩和参数验证
  • MySQL数据库零基础入门,数据库原理、SQL详解、库表操作、字段约束、基础查询全覆盖
  • 阅卷老师每天要看多少份试卷?机器帮了多少忙
  • 阳朔西街高性价比民宿推荐,舒适体验等你来享
  • 如何用Sunshine打造你的个人游戏云:终极开源串流服务器指南
  • Django+Vue双端权限系统模板,内置全国三级行政区划与一键容器化部署能力
  • 如何用HTTrack轻松实现网站全量备份与离线浏览:3种实用方法
  • 2026年惠州变压器回收品牌推荐与选择攻略 - 广东再生资源回收
  • SPI双缓冲机制与错误处理详解:从原理到实战避坑指南
  • 抖音内容采集革命:3分钟搞定无水印批量下载,工作效率提升10倍