Respuestas:
>>> '{0:08b}'.format(6)
'00000110'
Solo para explicar las partes de la cadena de formato:
{}
coloca una variable en una cadena0
toma la variable en la posición de argumento 0:
agrega opciones de formato para esta variable (de lo contrario, representaría decimal 6
)08
formatea el número a ocho dígitos con relleno de cero a la izquierdab
convierte el número a su representación binariaSi está utilizando una versión de Python 3.6 o superior, también puede usar cadenas f:
>>> f'{6:08b}'
'00000110'
0
significa el 0th
argumento de format
. Después de los dos puntos es el formato, el segundo 0
significa relleno de cero a 8 espacios y b
para binario
format()
función : format(6, '08b')
; la función toma un valor (a lo que se {..}
aplica el espacio) y una especificación de formato (lo que sea que coloque después :
de la cadena de formato).
Solo otra idea:
>>> bin(6)[2:].zfill(8)
'00000110'
Camino más corto a través de la interpolación de cadenas ( Python 3.6+ ):
>>> f'{6:08b}'
'00000110'
bin(-6)[2:].zfill(8)
lee como'0000b110'
Un poco de método de giro ...
>>> bin8 = lambda x : ''.join(reversed( [str((x >> i) & 1) for i in range(8)] ) )
>>> bin8(6)
'00000110'
>>> bin8(-3)
'11111101'
x
hacia la derecha y AND 1
, extrayendo efectivamente un bit (0 o 1) a la vez.
La respuesta de eumiro es mejor, sin embargo, solo estoy publicando esto para la variedad:
>>> "%08d" % int(bin(6)[2:])
00000110
'%08x' % int(bin(6)[2:], 16)
numpy.binary_repr(num, width=None)
tiene un argumento de ancho mágicoEjemplos relevantes de la documentación vinculada anteriormente:
>>> np.binary_repr(3, width=4) '0011'
El complemento de dos se devuelve cuando el número de entrada es negativo y se especifica el ancho:
>>> np.binary_repr(-3, width=5) '11101'
Ir a la vieja escuela siempre funciona
def intoBinary(number):
binarynumber=""
if (number!=0):
while (number>=1):
if (number %2==0):
binarynumber=binarynumber+"0"
number=number/2
else:
binarynumber=binarynumber+"1"
number=(number-1)/2
else:
binarynumber="0"
return "".join(reversed(binarynumber))
number=number/2
da flotación, por lo que number=number//2
parece mejor, también reemplazaría number=number//2
con number//=2
y b=b+"0"
conb+="0"
('0' * 7 + bin(6)[2:])[-8:]
o
right_side = bin(6)[2:]
'0' * ( 8 - len( right_side )) + right_side
La mejor manera es especificar el formato.
format(a, 'b')
devuelve el valor binario de a en formato de cadena.
Para convertir una cadena binaria a entero, use la función int ().
int('110', 2)
Devuelve el valor entero de una cadena binaria.
def int_to_bin(num, fill):
bin_result = ''
def int_to_binary(number):
nonlocal bin_result
if number > 1:
int_to_binary(number // 2)
bin_result = bin_result + str(number % 2)
int_to_binary(num)
return bin_result.zfill(fill)