it-roy-ru.com

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

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

например: я хочу передать 65 и получить '\x41' или 255 и получить '\xff'.

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

175
pynoob

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

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

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


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

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

185
Mike Graham

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

strHex = "0x%0.2X" % 255
121
Greg Bray

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

hex(255)  # 0xff

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

print '\\' + hex(255)[1:]
46
Felix Kling

Пытаться:

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

или же

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

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

39
Dawid

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

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

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

f'{15:x}'
> f

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

17
monkut

Если вы хотите упаковать структуру со значением <255 (один байт без знака, uint8_t) и получить строку из одного символа, вы, вероятно, ищете формат B вместо c . C преобразует символ в строку (сама по себе она не слишком полезна), а B преобразует целое число.

struct.pack('B', 65)

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

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

10
XTL

Обратите внимание, что для больших значений 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
5
Luc

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

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

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

"0x%03X" % 5  # => 0x005
"0x%03X" % 17 # => 0x011
4
shakram02

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

"#%6x" % random.randint(0xFFFFFF)
3
ncmathsadist

С 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
Map
(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
Chengcheng Zhang

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

[in] '%s' % hex(15)
[out]'0xf'
0
uzumaki