長い16進文字列からPythonバイトオブジェクトを作成するにはどうすればよいですか?
質問
など、文字列に16進数の長いシーケンスがあります
000000000000484240FA063DE5D0B744ADBED63A81FAEA390000C8428640A43D5005BD44
はるかに長く、数キロバイトです。これをPython 2.6 / 3のバイトオブジェクトに変換する組み込みの方法はありますか?
解決
python2.7を含むPython 2.7以降で動作します:
result = bytearray.fromhex('deadbeef')
注: Python 2.6の bytearray.fromhex()
関数にはバグがあるようです。 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`
他のヒント
result = bytes.fromhex(some_hex_string)
16進コーデックを使用してこれを行うことができます。例:
>>> 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'
をお試しください
from binascii import unhexlify
b = unhexlify(myhexstr)
import binascii
binascii.b2a_hex(obj)
所属していません StackOverflow