次のような文字列に16進数の長いシーケンスがあります。
000000000000484240FA063DE5D0B744ADBED63A81FAEA390000C8428640A43D5005BD44
ほんの数キロバイトです。これをpython 2.6/3のbytesオブジェクトに変換する組み込みの方法はありますか?
Python3を含む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'
binasciiモジュール を試してください
from binascii import unhexlify
b = unhexlify(myhexstr)
import binascii
binascii.a2b_hex(hex_string)
それが私がやった方法です。