struct模块提供将二进制数据转换为结构化数据或相反的功能,它定义了以下函数和异常:

  • exception struct.error
  • struct.pack(fmt, v1, v2, …)
  • 返回一个string,string由v1,v2…经过给出的格式fmt组成,参数的个数有和类型要和给出的格式一一对应
  • struct.pack_into(fmt, buffer, offset, v1, v2, …)
  • 按照格式fmt将v1, v2 …打包,并从buffer的偏移量offset开始写进buffer中
  • struct.unpack(fmt, string)
  • 以给定的格式fmt来将string解包,结果是个元组(tuple),即使结果只有一个值。fmt所要求的长度必须和string的长度相等
  • struct.unpack_from(fmt, buffer[, offset=0])
  • 以给定的格式fmt来将buffer解包,结果是个元组
  • struct.calcsize(fmt)
  • 返回给出格式对应的结构的长度

格式如下表:

C Type列指Foramt列字母所代表的打包数据

Python列指打包数据在python里面表示的类型

Format

C Type

Python

Notes

x

pad byte

no value

 

c

char

string of length 1

 

b

signed char

integer

 

B

unsigned char

integer

 

?

_Bool

bool

(1)

h

short

integer

 

H

unsigned short

integer

 

i

int

integer

 

I

unsigned int

integer or long

 

l

long

integer

 

L

unsigned long

long

 

q

long long

long

(2)

Q

unsigned long long

long

(2)

f

float

float

 

d

double

float

 

s

char[]

string

 

p

char[]

string

 

P

void *

long

 

说明:

  • 格式字符可以以一个数字作为前缀n,表示n个连续的该格式,例如4h表示hhhh
  • 在格式(formats)中间的空白字符将被忽略
  • s格式的计数n代表n个字节长度的string,例如’10s’代表10-byte string

format的第一个字符可以标示为字节序、对齐方式、数据类型大小等,如下表:

Character

Byte order

Size and alignment

@

native

native

=

native

standard

<

little-endian

standard

>

big-endian

standard

!

network (= big-endian)

standard

  • 如果没有第一个字符,则默认为@
  • native byteorder表示字节序取决于本机系统
  • native size and alignment表示数据类型大小和对齐方式与c编译器相关
  • standard size and alignment表示不进行任何对齐,short为2字节,int和long为4字节,long long为8字节,float和 double是32bit和64bit的IEEE的浮点数,_Bool为1字节