Python面试题:字节到大整数的打包与解包
生活随笔
收集整理的這篇文章主要介紹了
Python面试题:字节到大整数的打包与解包
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
需求:處理一個(gè)擁有128位長(zhǎng)的16個(gè)元素的字節(jié)字符串
將bytes解析為整數(shù),使用 int.from_bytes() 方法,并像下面這樣指定字節(jié)順序:
# 為了將bytes解析為整數(shù),使用 int.from_bytes() 方法,并像下面這樣指定字節(jié)順序: data = b'\x00\x124V\x00x\x90\xab\x00\xcd\xef\x01\x00#\x004' print(len(data)) # 16 # 如果byteorder為'big',則最重要的字節(jié)位于字節(jié)數(shù)組的開(kāi)頭。 如果byteorder為'little',則最重要的字節(jié)位于字節(jié)數(shù)組的末尾。 print(int.from_bytes(data,"little")) # 69120565665751139577663547927094891008 print(int.from_bytes(data,"big")) # 94522842520747284487117727783387188將一個(gè)大整數(shù)轉(zhuǎn)換為一個(gè)字節(jié)字符串,使用 int.to_bytes() 方法,并像下面這樣指定字節(jié)數(shù)和字節(jié)順序:
''' 遇到問(wèn)題沒(méi)人解答?小編創(chuàng)建了一個(gè)Python學(xué)習(xí)交流QQ群:778463939 尋找有志同道合的小伙伴,互幫互助,群里還有不錯(cuò)的視頻學(xué)習(xí)教程和PDF電子書(shū)! ''' x=69120565665751139577663547927094891008 # 如果byteorder為'big',則最重要的byte位于字節(jié)數(shù)組的開(kāi)頭。 如果byteorder為'little',則最重要的byte位于字節(jié)數(shù)組的末尾。 print(x.to_bytes(16,"little")) # b'\x00\x124V\x00x\x90\xab\x00\xcd\xef\x01\x00#\x004' print(x.to_bytes(16,"big")) # b'4\x00#\x00\x01\xef\xcd\x00\xab\x90x\x00V4\x12\x00'試著將一個(gè)整數(shù)打包為字節(jié)字符串
x=523**23 # print(x.to_bytes(16,"little")) # 報(bào)錯(cuò):OverflowError: int too big to convert # 解決:int.bit_length() 方法先判斷需要多少字節(jié)位來(lái)存儲(chǔ)這個(gè)值 print(x.bit_length()) # 208 意思是需要208個(gè)字節(jié)位存儲(chǔ) nbytes, rem = divmod(x.bit_length(), 8) print(nbytes, rem) # 26,0 if rem :nbytes+=1 print(nbytes, rem) # 26,0 print(x.to_bytes(nbytes,"little")) # b'\x03X\xf1\x82iT\x96\xac\xc7c\x16\xf3\xb9\xcf\x18\xee\xec\x91\xd1\x98\xa2\xc8\xd9R\xb5\xd0'總結(jié)
以上是生活随笔為你收集整理的Python面试题:字节到大整数的打包与解包的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: Python执行精确的浮点数运算
- 下一篇: websocket python爬虫_p