這篇文章給大家介紹怎么在Python中使用struct模塊,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
在struct模塊中最最常用的三個:
(1)struct.pack:用于將Python的值根據格式符,轉換為字符串(因為Python中沒有字節(Byte)類型,可以把這里的字符串理解為字節流,或字節數組)。
(2)struct.unpack: 剛好與struct.pack相反,用于將字節流轉換成python數據類型,該函數返回一個元組。
(3)struct.calcsize: 計算格式字符串所對應的結果的長度。
轉換過程中遇到的格式操作:
| 格式符 | C語言類型 | Python類型 |
|---|---|---|
| x | pad byte | no value |
| c | char | string of length 1 |
| b | signed char | integer |
| B | unsigned char | integer |
| ? | _Bool | bool |
| 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 |
| Q | unsigned long long | long |
| f | float | float |
| d | double | float |
| s | char[] | string |
| p | char[] | string |
| P | void * | long |
#!/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 '<ci:',calcsize('<ci')
print 'ic:',calcsize('ic')#計算格式占內存大小
print '@ic:',calcsize('@ic')
print '=ic:',calcsize('=ic')
print '>ic:',calcsize('>ic')
print '<ic:',calcsize('<ic')
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('<i',a)[0])
if __name__ == "__main__":
print '判斷本機是否為大小端?',
IsBig_Endian()
fun_calcsize()
print '大端:'
Format = ">ii"
fun_pack(Format)
fun_pack_into(Format)
print '小端:'
Format = "<ii"
fun_pack(Format)
fun_pack_into(Format)
print 'test'
test()
'''
result:
判斷本機是否為大小端? 本機為小端
ci: 8
@ci: 8
=ci: 5
>ci: 5
<ci: 5
ic: 5
@ic: 5
=ic: 5
>ic: 5
<ic: 5
大端:
pack <type 'str'> 0x11 0x22 0x33 0x44 0x55 0x66 0x77 0x88
unpack <type 'tuple'> 0x11223344 0x55667788
pack_into <type 'NoneType'> 0x11 0x22 0x33 0x44 0x55 0x66 0x77 0x88
pack_from <type 'tuple'> 0x11223344 0x55667788
小端:
pack <type 'str'> 0x44 0x33 0x22 0x11 0x88 0x77 0x66 0x55
unpack <type 'tuple'> 0x11223344 0x55667788
pack_into <type 'NoneType'> 0x44 0x33 0x22 0x11 0x88 0x77 0x66 0x55
pack_from <type 'tuple'> 0x11223344 0x55667788
test
字符1的二進制: 0x31
字符2的二進制: 0x32
字符3的二進制: 0x33
字符4的二進制: 0x34
大端:0x31323334
小端:0x34333231
'''關于怎么在Python中使用struct模塊就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。