我想取一个整数(这将是<= 255),以十六进制字符串表示
例:我想传入65并得到'\x41',或者255并得到'\xff'。
我尝试过用struct.pack('c',65)这样做,但它会阻塞任何超过9的东西,因为它想要接受单个字符串。
我想取一个整数(这将是<= 255),以十六进制字符串表示
例:我想传入65并得到'\x41',或者255并得到'\xff'。
我尝试过用struct.pack('c',65)这样做,但它会阻塞任何超过9的东西,因为它想要接受单个字符串。
当前回答
(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'
其他回答
这对我来说效果最好
"0x%02X" % 5 # => 0x05
"0x%02X" % 17 # => 0x11
如果你想要一个宽度更大的数字(2是2个十六进制打印字符),那么3会给你以下结果
"0x%03X" % 5 # => 0x005
"0x%03X" % 17 # => 0x011
你要找的是chr函数。
您似乎混合了整数的十进制表示和整数的十六进制表示,因此不完全清楚您需要什么。根据你的描述,我认为其中一个片段可以说明你想要什么。
>>> chr(0x65) == '\x65'
True
>>> hex(65)
'0x41'
>>> chr(65) == '\x41'
True
注意,这与包含十六进制整数的字符串完全不同。如果这是你想要的,使用十六进制内置。
我把这个加起来,因为有时候你只想要个位数表示
(x可以是小写字母'x',也可以是大写字母'x',选择决定输出的字母是大写还是小写。):
'{:x}'.format(15)
> f
现在有了新的f "格式字符串,你可以做:
f'{15:x}'
> f
要添加0填充,您可以使用0>n:
f'{2034:0>4X}'
> 07F2
注意:f'{15:x}'中的首字母'f'表示格式字符串
你可以用另一种表达方式
[in] '%s' % hex(15)
[out]'0xf'
Try:
"0x%x" % 255 # => 0xff
or
"0x%X" % 255 # => 0xFF
Python文档说:“把这个放在你的枕头下面:http://docs.python.org/library/index.html”