Python中msgpack库如何使用?

尊渡假赌尊渡假赌尊渡假赌
发布: 2025-11-25 21:49:32
原创
427人浏览过
msgpack是一种高效的二进制序列化格式,比JSON更小更快,适用于网络通信和缓存存储。通过pip install msgpack安装,使用packb()/unpackb()进行内存中数据的序列化与反序列化,支持dict、list、str、int等基本类型。可使用dump()/load()操作文件对象实现持久化存储。对于datetime等不支持的类型,可通过default和ext_hook参数自定义编码解码逻辑。注意默认情况下字符串key可能被转为bytes,需设置raw=False以保持为str类型。msgpack性能优越,适合在内部系统间高效传输数据。

python中msgpack库如何使用?

msgpack 是一种高效的二进制序列化格式,比 JSON 更小、更快。Python 中通过 msgpack 库实现对象的打包与解包。它适用于需要高性能数据交换的场景,比如网络通信、缓存存储等。

安装 msgpack

使用 pip 安装 msgpack Python 库:

pip install msgpack

注意:包名是 msgpack,但在代码中导入时写为 msgpack(不是 msgpack-python 或其他变体)。

基本序列化与反序列化

msgpack 支持常见 Python 数据类型:dict、list、str、int、float、bool 和 None。

立即学习Python免费学习笔记(深入)”;

示例:打包和解包基本数据

import msgpack

# 要序列化的数据
data = {
    'name': 'Alice',
    'age': 30,
    'is_student': False,
    'hobbies': ['reading', 'coding']
}

# 序列化为字节
packed_data = msgpack.packb(data)
print(packed_data) # 输出二进制数据

# 反序列化
unpacked_data = msgpack.unpackb(packed_data)
print(unpacked_data) # 输出原始数据结构

packb() 将对象转为字节串,unpackb() 将字节串还原。

处理文件读写

可以将数据直接写入文件或从文件读取,避免内存中保留完整字节串。

写入文件:

with open('data.msgpack', 'wb') as f:
    msgpack.dump(data, f)

读取文件:

易森网络企业版
易森网络企业版

如果您是新用户,请直接将本程序的所有文件上传在任一文件夹下,Rewrite 目录下放置了伪静态规则和筛选器,可将规则添加进IIS,即可正常使用,不用进行任何设置;(可修改图片等)默认的管理员用户名、密码和验证码都是:yeesen系统默认关闭,请上传后登陆后台点击“核心管理”里操作如下:进入“配置管理”中的&ld

易森网络企业版 0
查看详情 易森网络企业版
with open('data.msgpack', 'rb') as f:
    loaded_data = msgpack.load(f)

dump() 和 load() 用于文件对象操作,功能类似于 pickle 或 json 模块的对应方法。

处理不支持的类型(如 datetime)

msgpack 不原生支持 datetime、自定义类等复杂类型,但可以通过扩展方式处理。

使用 ext hooks 示例:

import msgpack
from datetime import datetime

def custom_encoder(obj):
    if isinstance(obj, datetime):
        return msgpack.ExtType(1, obj.isoformat().encode('utf-8'))
    raise TypeError(f"Unknown type: {type(obj)}")

def custom_decoder(code, data):
    if code == 1:
        return datetime.fromisoformat(data.decode('utf-8'))
    return msgpack.ExtType(code, data)

# 使用编码器和解码器
now = datetime.now()
packed = msgpack.packb(now, default=custom_encoder)
restored = msgpack.unpackb(packed, ext_hook=custom_decoder)
print(restored)

default 参数用于自定义序列化逻辑,ext_hook 处理解包时的扩展类型。

注意事项

msgpack 会将字符串转为 bytes 类型进行存储,在 Python 3 中需注意 str 与 bytes 的区别

默认情况下,unpackb 返回的 key 如果是字符串,可能在某些模式下被转为 bytes,可通过设置 raw=False 控制:

data = msgpack.unpackb(packed_data, raw=False)

这会让字符串 key 保持为 str 类型。

基本上就这些。msgpack 使用简单,性能高,适合替代 JSON 在内部系统间传递数据。注意类型兼容性和编码设置即可正常使用。

以上就是Python中msgpack库如何使用?的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号