長い16進文字列からPythonバイトオブジェクトを作成するにはどうすればよいですか?

StackOverflow https://stackoverflow.com/questions/443967

  •  22-07-2019
  •  | 
  •  

質問

など、文字列に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'

binasciiモジュール

をお試しください
from binascii import unhexlify
b = unhexlify(myhexstr)
import binascii

binascii.b2a_hex(obj)
ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top