У меня ABC123EFFF.
Я хочу иметь 0010101011111000001001000111110111111111111 (т.е. двоичное представление с, скажем, 42 цифрами и ведущими нулями).
Как?
У меня ABC123EFFF.
Я хочу иметь 0010101011111000001001000111110111111111111 (т.е. двоичное представление с, скажем, 42 цифрами и ведущими нулями).
Как?
Для решения левой задачи конечного нуля:
my_hexdata = "1a"
scale = 16 ## equals to hexadecimal
num_of_bits = 8
bin(int(my_hexdata, scale))[2:].zfill(num_of_bits)
Он будет давать 00011010 вместо обрезанной версии.
import binascii
binary_string = binascii.unhexlify(hex_string)
Read
Вернуть двоичные данные, представленные шестнадцатеричной строкой, указанной в качестве параметра.
bin(int("abc123efff", 16))[2:]
>>> bin( 0xABC123EFFF )
'0b1010101111000001001000111110111111111111'
Преобразовать шестнадцатеричное в двоичное
У меня есть ABC123EFFF.
I want to have 001010101111000001001000111110111111111111 (т.е. binary repr. with, say, 42 digits и leading zeroes).
Новые f-строки в Python 3.6 позволяют вам делать это, используя очень краткий синтаксис:
>>> 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'
и просто передайте это в формате
>>> 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-струны. Они используют одни и те же правила форматирования мини-языка:
>>> 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'
"{0:020b}".format(int('ABC123EFFF', 16))
Здесь довольно грубый способ сделать это, используя бит-скриптинг для генерации двоичных строк.
Ключевой бит для понимания:
(n & (1 << i)) and 1
Будет генерироваться либо 0, либо 1, если установлен i-й бит n.
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
(Какой TBH я не уверен, насколько это читаемо)
Это небольшое прикосновение к решению Глена Мейнарда, которое, я думаю, является правильным путем. Он просто добавляет элемент дополнений.
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,
, если вы работаете в автономном режиме script.
bin(int("abc123efff", 16))[2:]
'1010101111000001001000111110111111111111'
`bin(int("abc123efff", 16))[2:].zfill(50)`
'00000000001010101111000001001000111110111111111111'
(Число 50
сообщит zfill
, что вы хотите завершить строку нулями до тех пор, пока длина строки не будет 50
.)
Замените каждую шестнадцатеричную цифру на соответствующие четыре двоичные цифры:
1 - 0001
2 - 0010
...
a - 1010
b - 1011
...
f - 1111
hex → десятичный, затем десятичный → двоичный
#decimal to binary
def d2b(n):
bStr = ''
if n < 0: raise ValueError, "must be a positive integer"
if n == 0: return '0'
while n > 0:
bStr = str(n % 2) + bStr
n = n >> 1
return bStr
#hex to binary
def h2b(hex):
return d2b(int(hex,16))
Другой способ:
import math
def hextobinary(hex_string):
s = int(hex_string, 16)
num_digits = int(math.ceil(math.log(s) / math.log(2)))
digit_lst = ['0'] * num_digits
idx = num_digits
while s > 0:
idx -= 1
if s % 2 == 1: digit_lst[idx] = '1'
s = s / 2
return ''.join(digit_lst)
print hextobinary('abc123efff')
Я добавил расчет количества бит для заполнения в Onedinkenedi. Вот результирующая функция:
def hextobin(h):
return bin(int(h, 16))[2:].zfill(len(h) * 4)
Где 16 - база, из которой вы конвертируете (шестнадцатеричную), а 4 - количество бит, которое вам нужно представлять каждую цифру, или базу данных 2 шкалы.
def conversion():
e=raw_input("enter hexadecimal no.:")
e1=("a","b","c","d","e","f")
e2=(10,11,12,13,14,15)
e3=1
e4=len(e)
e5=()
while e3<=e4:
e5=e5+(e[e3-1],)
e3=e3+1
print e5
e6=1
e8=()
while e6<=e4:
e7=e5[e6-1]
if e7=="A":
e7=10
if e7=="B":
e7=11
if e7=="C":
e7=12
if e7=="D":
e7=13
if e7=="E":
e7=14
if e7=="F":
e7=15
else:
e7=int(e7)
e8=e8+(e7,)
e6=e6+1
print e8
e9=1
e10=len(e8)
e11=()
while e9<=e10:
e12=e8[e9-1]
a1=e12
a2=()
a3=1
while a3<=1:
a4=a1%2
a2=a2+(a4,)
a1=a1/2
if a1<2:
if a1==1:
a2=a2+(1,)
if a1==0:
a2=a2+(0,)
a3=a3+1
a5=len(a2)
a6=1
a7=""
a56=a5
while a6<=a5:
a7=a7+str(a2[a56-1])
a6=a6+1
a56=a56-1
if a5<=3:
if a5==1:
a8="000"
a7=a8+a7
if a5==2:
a8="00"
a7=a8+a7
if a5==3:
a8="0"
a7=a8+a7
else:
a7=a7
print a7,
e9=e9+1
У меня короткая надежда, которая помогает: -)
input = 'ABC123EFFF'
for index, value in enumerate(input):
print(value)
print(bin(int(value,16)+16)[3:])
string = ''.join([bin(int(x,16)+16)[3:] for y,x in enumerate(input)])
print(string)
сначала я использую ваш вход и перечисляю его, чтобы получить каждый символ. то я преобразовываю его в двоичный и обрезаю с 3-й позиции до конца. Трюк для получения 0 заключается в том, чтобы добавить максимальное значение ввода → в этом случае всегда 16:-)
краткая форма ist метода соединения. Наслаждайтесь.
# Python Program - Convert Hexadecimal to Binary
hexdec = input("Enter Hexadecimal string: ")
print(hexdec," in Binary = ", end="") # end is by default "\n" which prints a new line
for _hex in hexdec:
dec = int(_hex, 16) # 16 means base-16 wich is hexadecimal
print(bin(dec)[2:].rjust(4,"0"), end="") # the [2:] skips 0b, and the
Используйте встроенную функцию format() и функцию int() Это просто и легко понять. Это немного упрощенная версия ответа Аарона
Int()
int(string, base)
формат()
format(integer, # of bits)
ПримерExample
# 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
Смотрите также этот ответ
Двоичная версия ABC123EFFF на самом деле является 1010101111000001001000111110111111111111
Почти для всех приложений требуется, чтобы двоичная версия имела кратность 4 с начальным отступом 0 с.
Чтобы получить это в Python:
def hex_to_binary( hex_code ):
bin_code = bin( hex_code )[2:]
padding = (4-len(bin_code)%4)%4
return '0'*padding + bin_code
Пример 1:
>>> hex_to_binary( 0xABC123EFFF )
'1010101111000001001000111110111111111111'
Пример 2:
>>> hex_to_binary( 0x7123 )
'0111000100100011'
Обратите внимание, что это также работает в Micropython :)
a = raw_input('hex number\n')
length = len(a)
ab = bin(int(a, 16))[2:]
while len(ab)<(length * 4):
ab = '0' + ab
print ab
import binascii
hexa_input = input('Enter hex String to convert to Binary: ')
pad_bits=len(hexa_input)*4
Integer_output=int(hexa_input,16)
Binary_output= bin(Integer_output)[2:]. zfill(pad_bits)
print(Binary_output)
"""zfill(x) i.e. x no of 0 s to be padded left - Integers will overwrite 0 s
starting from right side but remaining 0 s will display till quantity x
[y:] where y is no of output chars which need to destroy starting from left"""
no=raw_input("Enter your number in hexa decimal :")
def convert(a):
if a=="0":
c="0000"
elif a=="1":
c="0001"
elif a=="2":
c="0010"
elif a=="3":
c="0011"
elif a=="4":
c="0100"
elif a=="5":
c="0101"
elif a=="6":
c="0110"
elif a=="7":
c="0111"
elif a=="8":
c="1000"
elif a=="9":
c="1001"
elif a=="A":
c="1010"
elif a=="B":
c="1011"
elif a=="C":
c="1100"
elif a=="D":
c="1101"
elif a=="E":
c="1110"
elif a=="F":
c="1111"
else:
c="invalid"
return c
a=len(no)
b=0
l=""
while b<a:
l=l+convert(no[b])
b+=1
print l