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

[Python] struct.unpack() 用法详解 - 指南

struct.unpack()用法详解


struct.unpack() 是 Python 中用于将二进制数据(字节序列)解析为 Python 数据类型的函数,通常与 struct.pack() 配对使用。它根据指定的格式字符串(format string)解析字节流,并返回一个包含解析结果的元组。


一、函数语法

struct.unpack(format
, buffer
)
  • format:格式字符串,定义数据的解析规则(字节顺序、数据类型、数量等)。
  • buffer:包含二进制数据的缓冲区(如 bytesbytearray 或支持缓冲协议的对象)。

返回值:包含解析后数据的元组。


二、格式字符串详解

格式字符串由两部分组成:

  1. 字节顺序/对齐字符(可选):

    字符含义大小端
    @本地顺序(默认)系统依赖
    =本地标准大小系统依赖
    <小端(Little-Endian)低位在前
    >大端(Big-Endian)高位在前
    !网络顺序(大端)RFC 标准
  2. 数据类型字符(必选):

    字符C 类型Python 类型字节数
    x填充字节跳过字节1
    ccharbytes (长度1)1
    bsigned charint1
    Bunsigned charint1
    ?_Boolbool1
    hshortint2
    Hunsigned shortint2
    iintint4
    Iunsigned intint4
    llongint4
    Lunsigned longint4
    qlong longint8
    Qunsigned long longint8
    ffloatfloat4
    ddoublefloat8
    schar[]bytes长度见下文
    pPascal 字符串bytes1+长度
    Pvoid*int系统依赖

    特殊用法


三、使用示例

示例 1:解析整数和浮点数
import struct
# 二进制数据:小端顺序 (<) + int (i) + float (f)
buffer = b'\x01\x00\x00\x00\xcd\xcc\x8c@'
data = struct.unpack('<if'
, buffer
) # 解析1个int和1个float
print(data) # 输出: (1, 7.000000476837158)
示例 2:解析字符串
# 数据:大端 (>) + 4字节字符串 (4s)
buffer = b'ABCD'
data = struct.unpack('>4s'
, buffer
)
print(data) # 输出: (b'ABCD',)
示例 3:解析混合类型
# 数据:小端 (<) + short (h) + 3字节字符串 (3s) + float (f)
buffer = b'\x01\x00XYZ\x00\x00\x80?'
data = struct.unpack('<h3sf'
, buffer
)
print(data) # 输出: (1, b'XYZ', 1.0)
示例 4:跳过填充字节
# 格式: 小端 (<) + char (c) + 填充1字节 (x) + int (i)
buffer = b'A\x00\x02\x00\x00\x00'
data = struct.unpack('<cx i'
, buffer
)
print(data) # 输出: (b'A', 2)
示例 5:解析数组
# 解析3个连续的 unsigned short (H)
buffer = b'\x01\x00\x02\x00\x03\x00'
data = struct.unpack('<3H'
, buffer
)
print(data) # 输出: (1, 2, 3)

四、关键注意事项

  1. 缓冲区长度必须匹配
    使用 struct.calcsize(format) 验证格式字符串所需的字节数:

    fmt = '<2i f'
    buffer = b'\x00' * struct.calcsize(fmt) # 创建匹配长度的缓冲区
  2. 字节顺序至关重要
    大端/小端错误会导致解析数值异常:

    # 错误示例:大端数据用小端解析
    buffer = b'\x00\x00\x00\x01' # 大端表示的整数 1
    struct.unpack('<I'
    , buffer
    ) # 错误!解析为 16777216 (0x01000000)
  3. 字符串处理
    s 类型返回 bytes 对象,需用 .decode() 转为字符串:

    data = struct.unpack('5s'
    , b'Hello'
    )[0]
    print(data.decode('utf-8'
    )
    ) # 输出: 'Hello'
  4. 内存对齐问题
    默认格式 @ 会按本地对齐方式插入填充字节。使用 = 或标准顺序(</>)避免对齐。


五、常见错误

通过合理设计格式字符串,struct.unpack() 可高效处理二进制协议(如网络数据、文件格式)。


研究学习不易,点赞易。
工作生活不易,收藏易,点收藏不迷茫 :)


http://www.jsqmd.com/news/9224/

相关文章:

  • 软件工程第一次随笔 - Nicholas
  • UV使用
  • CT5120 Intro to Natural Lang. Processing Lab # 4. Text Classification
  • 动手实验——mybatis generator
  • 迅速了解GO+ElasticSearch
  • 学生管理系统面向对象分析报告
  • 荷兰青少年通过Telegram被招募,涉嫌参与俄罗斯支持的黑客活动
  • Moscow International Workshops 2017. Day 4. Lviv NU Contest, GP of Ukraine
  • 云原生架构的演进与落地:重塑企业 IT 的核心能力 - 实践
  • 小代码使用npm包的方法
  • Kubernetes(K8s)核心架构解析与实用命令大全 - 教程
  • mzoj 2025/10/6
  • 在 Windows 系统下配置 VSCode + CMake + Ninja 进行 C++ 或 Qt 创建
  • 实验作业1-8 陆绎
  • 全源最短路 Johnson算法
  • UNION 与 UNION ALL 的区别 - 详解
  • 《对象创建的秘密:Java 内存布局、逃逸分析与 TLAB 优化详解》 - 实践
  • win11开机后卡死,磁盘c盘占用100%,解决方案
  • 跨越国度 解题报告
  • 手写Promise核心代码
  • 手动数据库分库分片策略
  • tmux 终端复用器教程,创建一个持久的会话
  • Java基础 Day28 完结篇 - 实践
  • 实用指南:第三十三天打卡复习
  • 实用指南:Hardening fixes lead to hard questions
  • 赛前训练6 状压
  • 排序综合
  • NKOJ全TJ计划——NP11745
  • InfinityFree教程 ——免费搭建属于你的网站
  • 深入解析:npm、yarn幽灵依赖问题