Odpowiedzi:
>>> '{0:08b}'.format(6)
'00000110'
Żeby wyjaśnić części ciągu formatującego:
{}
umieszcza zmienną w łańcuchu0
przyjmuje zmienną na pozycji argumentu 0:
dodaje opcje formatowania dla tej zmiennej (w przeciwnym razie reprezentowałaby liczbę dziesiętną 6
)08
formatuje liczbę do ośmiu cyfr z zerami po lewej stronieb
konwertuje liczbę na jej reprezentację binarnąJeśli używasz wersji Pythona 3.6 lub nowszej, możesz również użyć f-strings:
>>> f'{6:08b}'
'00000110'
0
oznacza 0th
argument do format
. Po dwukropku to formatowanie, druga 0
oznacza zero wypełnienia do 8 spacji, a b
dla binarnych
format()
funkcji :format(6, '08b')
; funkcja przyjmuje wartość (do czego{..}
odnosi się slot) i specyfikację formatowania (cokolwiek byś umieścił po ciągu:
w ciągu formatującym).
Po prostu kolejny pomysł:
>>> bin(6)[2:].zfill(8)
'00000110'
Krótszy sposób dzięki interpolacji ciągów ( Python 3.6+ ):
>>> f'{6:08b}'
'00000110'
bin(-6)[2:].zfill(8)
odczytywanych jako'0000b110'
Trochę dziwaczna metoda ...
>>> bin8 = lambda x : ''.join(reversed( [str((x >> i) & 1) for i in range(8)] ) )
>>> bin8(6)
'00000110'
>>> bin8(-3)
'11111101'
x
prawo i wykonuje operację AND 1
, skutecznie wydobywając jeden bit (0 lub 1) na raz.
odpowiedź eumiro jest lepsza, jednak publikuję to tylko dla odmiany:
>>> "%08d" % int(bin(6)[2:])
00000110
'%08x' % int(bin(6)[2:], 16)
numpy.binary_repr(num, width=None)
ma magiczny argument szerokościOdpowiednie przykłady z dokumentacji, do której link znajduje się powyżej:
>>> np.binary_repr(3, width=4) '0011'
Uzupełnienie do dwóch jest zwracane, gdy liczba wejściowa jest ujemna i określono szerokość:
>>> np.binary_repr(-3, width=5) '11101'
Going Old School zawsze działa
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
Daje pływaka, więc number=number//2
szwy lepiej, także chciałbym wymienić number=number//2
ze number//=2
i b=b+"0"
zeb+="0"
('0' * 7 + bin(6)[2:])[-8:]
lub
right_side = bin(6)[2:]
'0' * ( 8 - len( right_side )) + right_side
Najlepszym sposobem jest określenie formatu.
format(a, 'b')
zwraca wartość binarną a w formacie łańcucha.
Aby przekonwertować ciąg binarny z powrotem na liczbę całkowitą, użyj funkcji int ().
int('110', 2)
zwraca wartość całkowitą łańcucha binarnego.
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)