您好,登錄后才能下訂單哦!
這篇文章給大家介紹怎么在Python中使用struct模塊,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
在struct模塊中最最常用的三個:
(1)struct.pack:用于將Python的值根據(jù)格式符,轉(zhuǎn)換為字符串(因為Python中沒有字節(jié)(Byte)類型,可以把這里的字符串理解為字節(jié)流,或字節(jié)數(shù)組)。
(2)struct.unpack: 剛好與struct.pack相反,用于將字節(jié)流轉(zhuǎn)換成python數(shù)據(jù)類型,該函數(shù)返回一個元組。
(3)struct.calcsize: 計算格式字符串所對應(yīng)的結(jié)果的長度。
轉(zhuǎn)換過程中遇到的格式操作:
格式符 | 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')#計算格式占內(nèi)存大小 print '@ci:',calcsize('@ci') print '=ci:',calcsize('=ci') print '>ci:',calcsize('>ci') print '<ci:',calcsize('<ci') print 'ic:',calcsize('ic')#計算格式占內(nèi)存大小 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碼表中的字符轉(zhuǎn)換成對應(yīng)的整形,hex將數(shù)值轉(zhuǎn)化為十六進制 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的可變緩沖區(qū),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字符串,字符串按字節(jié)同a的二進制存儲內(nèi)容相同。 if hex(ord(result[0])) == '0x78': print '本機為小端' else: print '本機為大端' def test(): a = '1234' for i in a: print '字符%s的二進制:'%i,hex(ord(i))#字符對應(yīng)ascii碼表中對應(yīng)整數(shù)的十六進制 ''' 不用unpack()返回的數(shù)據(jù)也是可以使用pack()函數(shù)的,只要解包的字符串符合解包格式即可, pack()會按照解包格式將字符串在內(nèi)存中的二進制重新解釋(說的感覺不太好...,見下例) ''' 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 '''
關(guān)于怎么在Python中使用struct模塊就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。