我有ABC123EFFF。
我想要001010101111000001001000111110111111111111(即二进制表示,例如42位数字和前导零)。
如何实现?
我有ABC123EFFF。
我想要001010101111000001001000111110111111111111(即二进制表示,例如42位数字和前导零)。
如何实现?
解决左侧末尾零问题的方法:
my_hexdata = "1a"
scale = 16 ## equals to hexadecimal
num_of_bits = 8
bin(int(my_hexdata, scale))[2:].zfill(num_of_bits)
它会给出00011010而不是修剪后的版本。len(my_hexdata) * log2(scale)
。 - Eddzhex='0048'
时,你会得到 01001000
而不是 0000000001001000
。这个答案对我很有用。 - arman我有一个ABC123EFFF。
我想要得到001010101111000001001000111110111111111111(即用42位数字和前导零的二进制表示)。
Python 3.6中的新f-strings允许您使用非常简洁的语法来完成这个操作:
>>> f'{0xABC123EFFF:0>42b}'
'001010101111000001001000111110111111111111'
或者通过语义分解:
>>> number, pad, rjust, size, kind = 0xABC123EFFF, '0', '>', 42, 'b'
>>> f'{number:{pad}{rjust}{size}{kind}}'
'001010101111000001001000111110111111111111'
您实际上是想将十六进制表示的值转换为二进制表示的等效值。
等效值是一个整数。但是,您可能从一个字符串开始,并且要在二进制中查看,必须以字符串结束。
我们有几种直接的方法来实现这个目标,而无需使用切片技巧。
首先,在进行任何二进制操作之前,需要将其转换为int(我假设这是以字符串格式而不是字面量形式给出的):
>>> integer = int('ABC123EFFF', 16)
>>> integer
737679765503
或者我们可以使用十六进制形式表示的整数字面量:
>>> integer = 0xABC123EFFF
>>> integer
737679765503
现在我们需要用二进制表示法来表达我们的整数。
format
然后传递给 format
:
>>> format(integer, '0>42b')
'001010101111000001001000111110111111111111'
这里使用了格式化规范中的迷你语言。
为了解释清楚,这是它的语法形式:
[[fill]align][sign][#][0][width][,][.precision][type]
要将其转化为我们所需的规范,我们只需排除不需要的内容:
>>> spec = '{fill}{align}{width}{type}'.format(fill='0', align='>', width=42, type='b')
>>> spec
'0>42b'
只需将其传递给format函数即可。
>>> bin_representation = format(integer, spec)
>>> bin_representation
'001010101111000001001000111110111111111111'
>>> print(bin_representation)
001010101111000001001000111110111111111111
str.format
进行字符串格式化我们可以使用 str.format
方法对字符串进行格式化:
>>> 'here is the binary form: {0:{spec}}'.format(integer, spec=spec)
'here is the binary form: 001010101111000001001000111110111111111111'
或者直接将规范放在原始字符串中:
>>> 'here is the binary form: {0:0>42b}'.format(integer)
'here is the binary form: 001010101111000001001000111110111111111111'
让我们演示一下新的f-strings。它们使用相同的迷你语言格式规则:
>>> integer = 0xABC123EFFF
>>> length = 42
>>> f'{integer:0>{length}b}'
'001010101111000001001000111110111111111111'
现在让我们把这个功能放到一个函数中以鼓励可重用性:
def bin_format(integer, length):
return f'{integer:0>{length}b}'
现在:
>>> bin_format(0xABC123EFFF, 42)
'001010101111000001001000111110111111111111'
如果你只是想将数据编码为内存或磁盘上的字节串,可以使用int.to_bytes
方法,该方法仅在Python 3中可用:
>>> help(int.to_bytes)
to_bytes(...)
int.to_bytes(length, byteorder, *, signed=False) -> bytes
...
由于42位除以8位每字节等于6个字节:
>>> integer.to_bytes(6, 'big')
b'\x00\xab\xc1#\xef\xff'
import binascii
binary_string = binascii.unhexlify(hex_string)
阅读
将指定参数所代表的十六进制字符串转换为二进制数据并返回。
- Matt Goodunhexlify("ab") "\xab"
bin(int("abc123efff", 16))[2:]
>>> bin( 0xABC123EFFF )
'0b1010101111000001001000111110111111111111'
使用内置的format()函数和int()函数 它们简单易懂,是Aaron回答的简化版本。
int()
int(string, base)
format()
format(integer, # of bits)
示例
# w/o 0b prefix
>> format(int("ABC123EFFF", 16), "040b")
1010101111000001001000111110111111111111
# with 0b prefix
>> format(int("ABC123EFFF", 16), "#042b")
0b1010101111000001001000111110111111111111
# w/o 0b prefix + 64bit
>> format(int("ABC123EFFF", 16), "064b")
0000000000000000000000001010101111000001001000111110111111111111
请参考这个答案
"{0:020b}".format(int('ABC123EFFF', 16))
以下是使用位运算生成二进制字符串的相对基本的方法。
理解的关键在于:
(n & (1 << i)) and 1
如果n的第i位被设置,它将生成0或1。
import binascii
def byte_to_binary(n):
return ''.join(str((n & (1 << i)) and 1) for i in reversed(range(8)))
def hex_to_binary(h):
return ''.join(byte_to_binary(ord(b)) for b in binascii.unhexlify(h))
print hex_to_binary('abc123efff')
>>> 1010101111000001001000111110111111111111
编辑:使用“新”的三元运算符,可以这样写:
(n & (1 << i)) and 1
将变为:
1 if n & (1 << i) or 0
(说实话,我不确定那是否易读)
01111001
11111110
。 - Edison我为Onedinkenedi的解决方案添加了填充位数的计算。以下是生成的函数:
def hextobin(h):
return bin(int(h, 16))[2:].zfill(len(h) * 4)
这里的16是你要转换的基数(十六进制),4表示每个数字需要表示多少位,或者说是所使用比例的以2为底的对数。
这是对Glen Maynard的解决方案进行微调,我认为这是正确的方式。它只是添加了padding元素。
def hextobin(self, hexval):
'''
Takes a string representation of hex data with
arbitrary length and converts to string representation
of binary. Includes padding 0s
'''
thelen = len(hexval)*4
binval = bin(int(hexval, 16))[2:]
while ((len(binval)) < thelen):
binval = '0' + binval
return binval
self,
即可。
ABC123EFFF
--ABC123EFFF
是一个字符串还是数字(例如0xABC123EFFF
)? - hola