我想取一个整数(这将是<= 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'
其他回答
对于Python >= 3.6,使用f-string格式:
>>> x = 114514
>>> f'{x:0x}'
'1bf52'
>>> f'{x:#x}'
'0x1bf52'
你也可以把任何基数的任何数字转换成十六进制。使用这一行代码,它很容易使用:
十六进制(int x (n,) . replace(“0x”、“”)
你有一个字符串n是你的数字x是这个数字的底。首先,改变它为整数,然后十六进制,但十六进制有0x在它的第一个,所以替换我们删除它。
这将把一个整数转换成带有0x前缀的2位十六进制字符串:
strHex = "0x%0.2X" % integerVariable
我把这个加起来,因为有时候你只想要个位数表示
(x可以是小写字母'x',也可以是大写字母'x',选择决定输出的字母是大写还是小写。):
'{:x}'.format(15)
> f
现在有了新的f "格式字符串,你可以做:
f'{15:x}'
> f
要添加0填充,您可以使用0>n:
f'{2034:0>4X}'
> 07F2
注意:f'{15:x}'中的首字母'f'表示格式字符串
这对我来说效果最好
"0x%02X" % 5 # => 0x05
"0x%02X" % 17 # => 0x11
如果你想要一个宽度更大的数字(2是2个十六进制打印字符),那么3会给你以下结果
"0x%03X" % 5 # => 0x005
"0x%03X" % 17 # => 0x011