python struct模块格式化字符串,Python struct模块-深入学习

#!/usr/bin/python

# -*- coding:utf-8 -*-

'''测试struct模块'''

from struct import *

import array

def fun_calcsize():

print 'ci:',calcsize('ci')#计算格式占内存大小

print '@ci:',calcsize('@ci')

print '=ci:',calcsize('=ci')

print '>ci:',calcsize('>ci')

print '

print 'ic:',calcsize('ic')#计算格式占内存大小

print '@ic:',calcsize('@ic')

print '=ic:',calcsize('=ic')

print '>ic:',calcsize('>ic')

print '

def fun_pack(Format,msg = [0x11223344,0x55667788]):

result = pack(Format,*msg)

print 'pack'.ljust(10),str(type(result)).ljust(20),

for i in result:

print hex(ord(i)), # ord把ASCII码表中的字符转换成对应的整形,hex将数值转化为十六进制

print

result = unpack(Format,result)

print 'unpack'.ljust(10),str(type(result)).ljust(20),

for i in result:

print hex(i),

print

def fun_pack_into(Format,msg = [0x11223344,0x55667788]):

r = array.array('c',' '*8)#大小为8的可变缓冲区,writable buffer

result = pack_into(Format,r,0,*msg)

print 'pack_into'.ljust(10),str(type(result)).ljust(20),

for i in r.tostring():

print hex(ord(i)),

print

result = unpack_from(Format,r,0)

print 'pack_from'.ljust(10),str(type(result)).ljust(20),

for i in result:

print hex(i),

print

def IsBig_Endian():

'''判断本机为大/小端'''

a = 0x12345678

result = pack('i',a)#此时result就是一个string字符串,字符串按字节同a的二进制存储内容相同。

if hex(ord(result[0])) == '0x78':

print '本机为小端'

else:

print '本机为大端'

def test():

a = '1234'

for i in a:

print '字符%s的二进制:'%i,hex(ord(i))#字符对应ascii码表中对应整数的十六进制

'''

不用unpack()返回的数据也是可以使用pack()函数的,只要解包的字符串符合解包格式即可,

pack()会按照解包格式将字符串在内存中的二进制重新解释(说的感觉不太好...,见下例)

'''

print '大端:',hex(unpack('>i',a)[0])#因为pack返回的是元组,即使只有一个元素也是元组的形式

print '小端:',hex(unpack('

if __name__ == "__main__":

print '判断本机是否为大小端?',

IsBig_Endian()

fun_calcsize()

print '大端:'

Format = ">ii"

fun_pack(Format)

fun_pack_into(Format)

print '小端:'

Format = "

fun_pack(Format)

fun_pack_into(Format)

print 'test'

test()

'''

result:

判断本机是否为大小端? 本机为小端

ci: 8

@ci: 8

=ci: 5

>ci: 5

ic: 5

@ic: 5

=ic: 5

>ic: 5

大端:

pack 0x11 0x22 0x33 0x44 0x55 0x66 0x77 0x88

unpack 0x11223344 0x55667788

pack_into 0x11 0x22 0x33 0x44 0x55 0x66 0x77 0x88

pack_from 0x11223344 0x55667788

小端:

pack 0x44 0x33 0x22 0x11 0x88 0x77 0x66 0x55

unpack 0x11223344 0x55667788

pack_into 0x44 0x33 0x22 0x11 0x88 0x77 0x66 0x55

pack_from 0x11223344 0x55667788

test

字符1的二进制: 0x31

字符2的二进制: 0x32

字符3的二进制: 0x33

字符4的二进制: 0x34

大端:0x31323334

小端:0x34333231

'''

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
struct模块Python中用于处理二进制数据的模块。它提供了一种通过定义结构体来解析和打包数据的方法,用于处理不同字节长度和字节顺序的数据。 使用struct模块,你可以将数据打包成二进制字符串,或者从二进制字符串中解析出特定类型的数据。这在处理网络通信、文件读写、操作硬件设备等场景下非常有用。 要使用struct模块,你首先需要导入它,然后可以使用其中的函数来执行各种操作。一些常用的函数包括: - struct.pack(format, v1, v2, ...):将指定的值按照给定的格式(format)打包成二进制字符串。 - struct.unpack(format, string):按照给定的格式(format)从二进制字符串中解析出对应的值。 - struct.calcsize(format):返回给定格式(format)的结构体所占用的字节数。 在format参数中,你可以使用各种格式化字符来表示不同类型的数据,如整数、浮点数、字符串等,并可以指定字节顺序和字节对齐方式。 例如,以下是一个使用struct模块打包和解析数据的示例: ```python import struct # 打包数据 packed_data = struct.pack('iif', 1, 2, 3.14) print(packed_data) # 输出:b'\x01\x00\x00\x00\x02\x00\x00\x00\xd0\x0f\x49\x40' # 解析数据 unpacked_data = struct.unpack('iif', packed_data) print(unpacked_data) # 输出:(1, 2, 3.140000104904175) ``` 在上面的示例中,我们使用'iif'格式来表示一个整数、一个整数和一个浮点数。通过pack函数打包这些数据后,得到了一个二进制字符串。然后,使用unpack函数从该二进制字符串中解析出相应的值。 除了上述常用的函数和格式化字符外,struct模块还提供了其他一些函数和格式化字符,用于处理更复杂的数据结构。你可以查阅官方文档来了解更多详细信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值