文字列に16進数の長いシーケンスがあります。
000000000000484240FA063DE5D0B744ADBED63A81FAEA390000C8428640A43D5005BD44
はるかに長く、数キロバイトです。Python 2.6 / 3でこれをbytesオブジェクトに変換する組み込みの方法はありますか?
文字列に16進数の長いシーケンスがあります。
000000000000484240FA063DE5D0B744ADBED63A81FAEA390000C8428640A43D5005BD44
はるかに長く、数キロバイトです。Python 2.6 / 3でこれをbytesオブジェクトに変換する組み込みの方法はありますか?
回答:
python3を含むPython2.7以降で動作します。
result = bytearray.fromhex('deadbeef')
注: Python2.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`
bytes(bytearray.fromhex('deadbeef'))
binascii.unhexlify()
ます。
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'
codecs.decode('0a0a0a', 'hex_codec')
2.xおよび3.xで動作するはずです:
binasciiモジュールを試してください
from binascii import unhexlify
b = unhexlify(myhexstr)
unhexlify
、文字列を受け入れず、バイトのみを受け入れるようになったことに注意してください。本当にばかげていますが、それはあなたが使用する必要があることを意味しますb = unhexlify(bytes(myhexstr, 'utf-8'))
import binascii
binascii.a2b_hex(hex_string)
それが私がやった方法です。
import binascii
binascii.b2a_hex(obj)