Как преобразовать int в шестнадцатеричную строку?

Я хочу взять целое число (которое будет < = 255) в шестнадцатеричное представление строки

например.: Я хочу пройти в 65 и выйти ' \ x41 ' или 255 и получить ' \ xff '.

Я пытался сделать это с struct.pack ('c',65), но это душит что-либо выше 9, так как он хочет взять в одной строке символов.

Решение

Вы ищете функцию chr.

Вы, кажется, смешиваете десятичные представления целых чисел и шестнадцатеричные представления целых чисел, поэтому не совсем понятно, что вам нужно. Основываясь на описании, которое вы дали, я думаю, что один из этих фрагментов показывает, что вы хотите.

>>> chr(0x65) == '\x65'
True

>>> hex(65)
'0x41'
>>> chr(65) == '\x41'
True

Обратите внимание, что это сильно отличается от строки, содержащей целое число в виде гекса . Если это то, что вы хотите, используйте встроенный hex.

Комментарии (5)

Это преобразует целое число в двухзначную шестнадцатеричную строку с префиксом 0x:

strHex = "0x%0.2X" % 255
Комментарии (2)

Как насчет hex ()?

hex(255)  # 0xff

Если вы действительно хотите иметь \перед, вы можете сделать:

print '\\' + hex(255)[1:]
Комментарии (1)

Попробуй:

"0x%x" % 255 # => 0xff

или

"0x%X" % 255 # => 0xFF

Документация Python гласит: «Держите это под подушкой: http://docs.python.org/library/index.html»

Комментарии (0)

Позвольте мне добавить это, потому что иногда вы просто хотите однозначное представление:

'{:x}'.format(15)
> f

А теперь с новыми строками формата f '' вы можете сделать:

f'{15:x}'
> f

ПРИМЕЧАНИЕ: начальный 'f' в f '{15: x}' ' должен означать строку формата

Комментарии (1)

Если вы хотите упаковать структуру со значением < 255 (один байт без знака, uint8_t) и в итоге получить строку из одного символа, вы, вероятно, ищете < a href = "http://docs.python.org/library/struct.html#format-characters" > формат B вместо c < >. C преобразует символ в строку (сам по себе не слишком полезный), а B преобразует целое число.

struct.pack('B', 65)

(И да, 65 - это \ x41, а не \ x65.)

Класс структуры также будет удобно обрабатывать конечность для связи или других целей.

Комментарии (1)

Обратите внимание, что для больших значений hex () все еще работает (некоторые другие ответы не работают):

x = hex(349593196107334030177678842158399357)
print(x)

Python 2: 0x4354467b746f6f5f736d616c6c3f7dL Python 3: 0x4354467b746f6f5f736d616c6c3f7d

Для расшифрованного сообщения RSA можно сделать следующее:

import binascii

hexadecimals = hex(349593196107334030177678842158399357)

print(binascii.unhexlify(hexadecimals[2:-1])) # python 2
print(binascii.unhexlify(hexadecimals[2:])) # python 3
Комментарии (0)

Это сработало лучше всего для меня

"0x%02X" % 5  # => 0x05
"0x%02X" % 17 # => 0x11

Измените (2), если вы хотите число с большей шириной (2 для 2 шестигранных символов с печатью), чтобы 3 дало вам следующее

"0x%03X" % 5  # => 0x005
"0x%03X" % 17 # => 0x011
Комментарии (0)

Я хотел, чтобы случайное целое число было преобразовано в шестизначную шестнадцатеричную строку с # в начале. Чтобы получить это, я использовал

"#%6x" % random.randint(0xFFFFFF)
Комментарии (2)

С помощью format (), согласно format-examples, мы можем сделать:

>>> # format also supports binary numbers
>>> "int: {0:d};  hex: {0:x};  oct: {0:o};  bin: {0:b}".format(42)
'int: 42;  hex: 2a;  oct: 52;  bin: 101010'
>>> # with 0x, 0o, or 0b as prefix:
>>> "int: {0:d};  hex: {0:#x};  oct: {0:#o};  bin: {0:#b}".format(42)
'int: 42;  hex: 0x2a;  oct: 0o52;  bin: 0b101010'
Комментарии (0)
(int_variable).to_bytes(bytes_length, byteorder='big'|'little').hex()

Например:

>>> (434).to_bytes(4, byteorder='big').hex()
'000001b2'
>>> (434).to_bytes(4, byteorder='little').hex()
'b2010000'
Комментарии (0)

В качестве альтернативного представления вы можете использовать

[in] '%s' % hex(15)
[out]'0xf'
Комментарии (0)