我在字符串中有很长的十六进制数字序列,例如
000000000000484240FA063DE5D0B744ADBED63A81FAEA390000C8428640A43D5005BD44
只有更长的时间,几千字节。有内置的方法可以将其转换为python 2.6 / 3中的bytes对象吗?
我在字符串中有很长的十六进制数字序列,例如
000000000000484240FA063DE5D0B744ADBED63A81FAEA390000C8428640A43D5005BD44
只有更长的时间,几千字节。有内置的方法可以将其转换为python 2.6 / 3中的bytes对象吗?
Answers:
在Python 2.7及更高版本(包括python3)中工作:
result = bytearray.fromhex('deadbeef')
注意:bytearray.fromhex()
Python 2.6中的函数似乎存在一个错误。python.org文档指出该函数接受字符串作为参数,但在应用时会引发以下错误:
>>> bytearray.fromhex('B9 01EF')
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: fromhex() argument 1 must be unicode, not str`
bytes(bytearray.fromhex('deadbeef'))
binascii.unhexlify()
。
result = bytes.fromhex(some_hex_string)
您可以使用十六进制编解码器执行此操作。即:
>>> s='000000000000484240FA063DE5D0B744ADBED63A81FAEA390000C8428640A43D5005BD44'
>>> s.decode('hex')
'\x00\x00\x00\x00\x00\x00HB@\xfa\x06=\xe5\xd0\xb7D\xad\xbe\xd6:\x81\xfa\xea9\x00\x00\xc8B\x86@\xa4=P\x05\xbdD'
codecs.decode('0a0a0a', 'hex_codec')
应该为2.x和3.x工作:-)
from binascii import unhexlify
b = unhexlify(myhexstr)
unhexlify
现在将不接受字符串,而仅接受字节。真的很傻,但这意味着您需要使用b = unhexlify(bytes(myhexstr, 'utf-8'))
import binascii
binascii.a2b_hex(hex_string)
那就是我做到的方式。