python struct 详解

from http://blog.csdn.net/jgood/article/details/4290158

struct.pack

  struct.pack用于将Python的值根据格式符,转换为字符串(因为Python中没有字节(Byte)类型,可以把这里的字符串理解为字节流,或字节数组)。其函数原型为:struct.pack(fmt, v1, v2, ...),参数fmt是格式字符串,关于格式字符串的相关信息在下面有所介绍。v1, v2, ...表示要转换的python值。下面的例子将两个整数转换为字符串(字节流):

[python]  view plain copy
  1. import struct  
  2.   
  3. a = 20  
  4. b = 400  
  5.   
  6. str = struct.pack("ii", a, b)  #转换后的str虽然是字符串类型,但相当于其他语言中的字节流(字节数组),可以在网络上传输  
  7. print 'length:', len(str)  
  8. print str  
  9. print repr(str)  
  10.   
  11. #---- result  
  12. #length: 8  
  13. #    ----这里是乱码  
  14. #'/x14/x00/x00/x00/x90/x01/x00/x00'  

格式符"i"表示转换为int,'ii'表示有两个int变量。进行转换后的结果长度为8个字节(int类型占用4个字节,两个int为8个字节),可以看到输出的结果是乱码,因为结果是二进制数据,所以显示为乱码。可以使用python的内置函数repr来获取可识别的字符串,其中十六进制的0x00000014, 0x00000190分别表示20和400。

struct.unpack

  struct.unpack做的工作刚好与struct.pack相反,用于将字节流转换成python数据类型。它的函数原型为:struct.unpack(fmt, string),该函数返回一个元组。 下面是一个简单的例子:

[python]  view plain copy
  1. str = struct.pack("ii"20400)  
  2. a1, a2 = struct.unpack("ii", str)  
  3. print 'a1:', a1  
  4. print 'a2:', a2  
  5.   
  6. #---- result:  
  7. #a1: 20  
  8. #a2: 400  

struct.calcsize

  struct.calcsize用于计算格式字符串所对应的结果的长度,如:struct.calcsize('ii'),返回8。因为两个int类型所占用的长度是8个字节。

struct.pack_into, struct.unpack_from

   这两个函数在Python手册中有所介绍,但没有给出如何使用的例子。其实它们在实际应用中用的并不多。Google了很久,才找到一个例子,贴出来共享一下:

[python]  view plain copy
  1. import struct  
  2. from ctypes import create_string_buffer  
  3.   
  4. buf = create_string_buffer(12)  
  5. print repr(buf.raw)  
  6.   
  7. struct.pack_into("iii", buf, 012, -1)  
  8. print repr(buf.raw)  
  9.   
  10. print struct.unpack_from('iii', buf, 0)  
  11.   
  12. #---- result  
  13. #'/x00/x00/x00/x00/x00/x00/x00/x00/x00/x00/x00/x00'  
  14. #'/x01/x00/x00/x00/x02/x00/x00/x00/xff/xff/xff/xff'  
  15. #(1, 2, -1)  

关于格式字符串

  在Python手册中,给出了C语言中常用类型与Python类型对应的格式符:

格式符C语言类型Python类型
xpad byteno value 
ccharstring of length 1 
bsigned charinteger 
Bunsigned charinteger 
?_Boolbool 
hshortinteger 
Hunsigned shortinteger 
iintinteger 
Iunsigned intinteger or long 
llonginteger 
Lunsigned longlong 
qlong longlong 
Qunsigned long longlong 
ffloatfloat 
ddoublefloat 
schar[]string 
pchar[]string 
Pvoid *long

具体内容请参考Python手册 struct 模块

  • 3
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
回答: 在Python中,struct模块提供了pack和unpack函数用于将任意数据类型转换成字节流以及将字节流解析为原始数据类型。 pack函数的用法如下所示: import struct data = struct.pack('>I', 10240099) 在这个例子中,我们使用大端字节序('>I')将整型数字10240099转换成字节流。pack函数的第一个参数是格式化字符串,用于指定数据的类型和字节顺序。 '>I' 表示使用大端字节序(高位字节在前),并且数据类型为无符号整型。pack的第二个参数是要转换的数据。 而unpack函数的用法如下所示: import struct data = b'\x00\x9c@c' result = struct.unpack('>I', data) 在这个例子中,我们使用大端字节序('>I')将字节流数据解析为整型数字。unpack函数的第一个参数是格式化字符串,用于指定数据的类型和字节顺序。'>I' 表示使用大端字节序(高位字节在前),并且数据类型为无符号整型。unpack的第二个参数是要解析的字节流数据。 此外,struct模块还提供了其他功能,比如用于处理字节的buffer方式、处理字节和其他数据类型的转换等。这些功能可以根据具体的需求灵活使用。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [pythonstruct详解](https://blog.csdn.net/qq_30638831/article/details/80421019)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值