Преобразовать шестнадцатеричный в двоичный

107

У меня ABC123EFFF.

Я хочу иметь 001010101111000001001000111110111111111111 (т.е. двоичное представление, скажем, с 42 цифрами и ведущими нулями).

Как?

Аарон Холл
источник

Ответы:

106

Для решения левой задачи конечного нуля:


my_hexdata = "1a"

scale = 16 ## equals to hexadecimal

num_of_bits = 8

bin(int(my_hexdata, scale))[2:].zfill(num_of_bits)

Вместо урезанной версии будет 00011010.

Онединкенеди
источник
4
Расчет количества битов есть len(my_hexdata) * log2(scale).
Эдд
4
Не предоставляет
Dragon
@Dragon myhex = '1A' bin (int (myhex, 16)) [2:]. Zfill (8) >>> '00011010' zhex = '00' bin (int (zhex, 16)) [2:]. zfill (8) >>> '00000000' Похоже, что это работает, даже если шестнадцатеричная строка равна '00'.
DeanM
59
import binascii

binary_string = binascii.unhexlify(hex_string)

Читать

binascii.unhexlify

Возвращает двоичные данные, представленные шестнадцатеричной строкой, указанной в качестве параметра.

рахул
источник
17
Это возвращает «двоичный», как в фактических байтах, но не преобразует его в печатное представление как «0» и «1».
Мэтт Гуд,
docs.python.org/library/binascii.html имеет подзаголовок Преобразование между двоичным кодом и ASCII. Разве это не значит, что он возвращает строку?
павиум
Да, он возвращает строку, содержащую представленные байты, например >>> unhexlify ("ab") "\ xab"
Мэтт Гуд,
9
Есть идеи, как вернуть «001010100»?
Дэвид 天宇 Вонг
1
Я не знаю, почему за это проголосовали, поскольку он не отвечает на фактический запрос ОП - см. Любой из других сообщений для ответа
Дэвид Глэнс
45
bin(int("abc123efff", 16))[2:]
Гленн Мейнард
источник
7
Если введено «1a», это дает «11010», а не «00011010», что может быть или не быть тем, что вы хотите.
Мэтт Гуд,
4
Вполне разумно нули в начале (и не нужны). Например, вы можете захотеть, чтобы нулевой байт 0x00 состоял из восьми нулевых битов - это важно для некоторых приложений. Также OP имеет начальный ноль в его примере (но я подозреваю, что в данном случае это просто случайность!)
Скотт Гриффитс
42

Преобразовать шестнадцатеричный в двоичный

У меня ABC123EFFF.

Я хочу иметь 001010101111000001001000111110111111111111 (т.е. двоичное представление, скажем, с 42 цифрами и ведущими нулями).

Короткий ответ:

Новые 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'

Длинный ответ:

На самом деле вы говорите, что у вас есть значение в шестнадцатеричном представлении, и вы хотите представить эквивалентное значение в двоичном.

Значение эквивалентности - целое число. Но вы можете начать со строки, а для просмотра в двоичном формате вы должны заканчивать строкой.

Преобразовать шестнадцатеричное в двоичное, 42 цифры и ведущие нули?

У нас есть несколько способов достичь этой цели напрямую, без использования срезов.

Во-первых, прежде чем мы вообще сможем выполнять какие-либо двоичные манипуляции, преобразуйте его в 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'
Аарон Холл
источник
31
>>> bin( 0xABC123EFFF )

'0b1010101111000001001000111110111111111111'

просто
источник
2
Не предоставляет
Dragon
14
"{0:020b}".format(int('ABC123EFFF', 16))
Маркус
источник
3
Не предоставляет
Dragon
10

Вот довольно простой способ сделать это, используя битовую игру для генерации двоичных строк.

Ключевой момент, который нужно понять:

(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 я не уверен, насколько это читаемо)

Джон Монтгомери
источник
1
Я знаю, что это устарело, но в чем именно смысл «и»?
Goodies
Это для старых времен Python до тернарного оператора. (N & (1 << i)) либо вернет ноль, либо что-то другое, кроме нуля. Нам нужна только единица или ноль, чтобы гарантировать это.
Джон Монтгомери
Этот сценарий лучше всего работал для меня, чтобы преобразовать криптографический закрытый ключ из шестнадцатеричного в двоичный для целей тестирования. Кто-нибудь знает, как разбить двоичную строку на 8-битные куски и распечатать ее? то есть 01111001 11111110.
Эдисон
5

Это небольшое изменение решения Глена Мейнарда, и я думаю, что это правильный способ сделать это. Он просто добавляет элемент заполнения.


    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, если вы работаете в автономном скрипте.

РоботЧеловек
источник
5

Использование встроенной функции формата () и Int () функцию Это просто и легко понять. Это немного упрощенная версия ответа Аарона

int ()

int(string, base)

формат()

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

См. Также этот ответ

никто
источник
3

Замените каждую шестнадцатеричную цифру соответствующими 4 двоичными цифрами:

1 - 0001
2 - 0010
...
a - 1010
b - 1011
...
f - 1111
ДмитрийК
источник
2
Или замените каждую пару шестнадцатеричных цифр соответствующими 8 двоичными цифрами, или замените каждую тройку шестнадцатеричных цифр соответствующими 12 двоичными цифрами ... или замените каждые 10 шестнадцатеричных цифр соответствующими 40 двоичными цифрами - Ой! туда, откуда мы начали!
павиум
2

шестнадцатеричный -> десятичный, затем десятичный -> двоичный

#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))

источник
1

По-другому:

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')
ChristopheD
источник
Это не удается, если для hex_string установлено значение 'f0'
mikemaccana
1

Я добавил расчет количества бит для заполнения в решение Онединкенеди. Вот итоговая функция:

def hextobin(h):
  return bin(int(h, 16))[2:].zfill(len(h) * 4)

Где 16 - это основание, из которого вы конвертируете (шестнадцатеричное), а 4 - это количество бит, которое вам нужно для представления каждой цифры, или логарифмическая база 2 шкалы.

Эдд
источник
0
 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
Харшит Гупта
источник
0

у меня есть короткая оборванная надежда, которая помогает :-)

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 :-)

краткая форма - это метод соединения. Наслаждаться.

Джон
источник
0
# 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 
мой ассал
источник
0

Двоичная версия ABC123EFFF на самом деле 1010101111000001001000111110111111111111

Почти для всех приложений вы хотите, чтобы двоичная версия имела длину, кратную 4, с начальным заполнением нулей.

Чтобы получить это в 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 :)

Стефан
источник
0

Просто используйте код модуля (примечание: я являюсь автором модуля)

Здесь вы можете преобразовать шестнадцатеричный код в двоичный.

  1. Установить с помощью pip
pip install coden
  1. Перерабатывать
a_hexadecimal_number = "f1ff"
binary_output = coden.hex_to_bin(a_hexadecimal_number)

Конвертирующие ключевые слова:

  • шестнадцатеричный для шестнадцатеричного
  • bin для двоичного
  • int для десятичного числа
  • _to_ - ключевое слово преобразования для функции

Таким образом, вы также можете форматировать: e. шестнадцатеричный_выход = bin_to_hex (a_binary_number)

математика
источник
0

HEX_TO_BINARY_CONVERSION_TABLE = {'0': '0000',

                              '1': '0001',

                              '2': '0010',

                              '3': '0011',

                              '4': '0100',

                              '5': '0101',

                              '6': '0110',

                              '7': '0111',

                              '8': '1000',

                              '9': '1001',

                              'a': '1010',

                              'b': '1011',

                              'c': '1100',

                              'd': '1101',

                              'e': '1110',

                              'f': '1111'}

def hex_to_binary(hex_string):
    binary_string = ""
    for character in hex_string:
        binary_string += HEX_TO_BINARY_CONVERSION_TABLE[character]
    return binary_string
Йылмаз
источник
-1
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
Ашвини
источник
7
Где описание / объяснение?
Суфиан
-1
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"""
Хаттанему
источник
-7
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
предупреждать
источник