Как создать объект python bytes из длинной шестнадцатеричной строки?

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

  •  22-07-2019
  •  | 
  •  

Вопрос

У меня есть длинная последовательность шестнадцатеричных цифр в строке, например

000000000000484240FA063DE5D0B744ADBED63A81FAEA390000C8428640A43D5005BD44

только гораздо длиннее, несколько килобайт.Есть ли встроенный способ преобразовать это в объект bytes в python 2.6 / 3?

Это было полезно?

Решение

Работает на Python 2.7 и выше, включая python3:

result = bytearray.fromhex('deadbeef')

Примечание: Кажется, есть ошибка с bytearray.fromhex() функция в Python 2.6.В документации 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)

Вы можете сделать это с помощью шестнадцатеричного кодека.ie:

>>> 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