webdevqa.jp.net

長い16進文字列からpython bytesオブジェクトを作成するには?

次のような文字列に16進数の長いシーケンスがあります。

000000000000484240FA063DE5D0B744ADBED63A81FAEA390000C8428640A43D5005BD44

ほんの数キロバイトです。これをpython 2.6/3のbytesオブジェクトに変換する組み込みの方法はありますか?

71
recursive

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`
_
69
Jim Garrison
result = bytes.fromhex(some_hex_string)
52
vili

16進コーデックを使用してこれを行うことができます。すなわち:

>>> s='000000000000484240FA063DE5D0B744ADBED63A81FAEA390000C8428640A43D5005BD44'
>>> s.decode('hex')
'\x00\x00\x00\x00\x00\[email protected]\xfa\x06=\xe5\xd0\xb7D\xad\xbe\xd6:\x81\xfa\xea9\x00\x00\xc8B\[email protected]\xa4=P\x05\xbdD'
40
Brian

binasciiモジュール を試してください

from binascii import unhexlify
b = unhexlify(myhexstr)
35
Crescent Fresh
import binascii

binascii.a2b_hex(hex_string)

それが私がやった方法です。

1
JustPlayin