16進数をバイナリに変換


回答:


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)です。
Edd 2015年

4
16進数文字列が00で始まる場合、先行ゼロを提供していません
ドラゴン

@Dragon myhex = '1A' bin(int(myhex、16))[2:]。zfill(8)>>> '00011010' zhex = '00' bin(int(zhex、16))[2:]。 zfill(8)>>> '00000000'これは、16進文字列が '00'の場合でも機能するようです。
DeanM

58
import binascii

binary_string = binascii.unhexlify(hex_string)

読んだ

binascii.unhexlify

パラメータとして指定された16進文字列で表されるバイナリデータを返します。


17
これは実際のバイトのように「バイナリ」を返しますが、「0」と「1」のような印刷可能な表現に変換しません。
マットグッド

docs.python.org/library/binascii.htmlは、バイナリとASCIIの間の変換というタイトルです。それは文字列を返すことを意味しませんか?
パビウム2009

はい、表されたバイトを含む文字列を返します。例:>>> unhexlify( "ab") "\ xab"
Matt Good

9
「001010100」を返す方法はありますか?
David天宇Wong

1
OPの実際のリクエストに回答しないので、なぜこれが投票されたのかわかりません。回答については、他の投稿を参照してください
David Glance

45
bin(int("abc123efff", 16))[2:]

7
入力が「1a」の場合、これは「00011010」ではなく「11010」を示します。これは、必要な場合とそうでない場合があります。
マットグッド

4
先行ゼロを必要とする(そしてそれらを必要としない)ことはかなり合理的です。たとえば、ヌルバイト0x00を8つのゼロビットにしたい場合があります-これは一部のアプリケーションにとって重要です。また、OPの例には先行ゼロがあります(ただし、この場合はランダムだと思います!)
スコットグリフィス

42

16進数をバイナリに変換

ABC123EFFFがあります。

私は001010101111000001001000111110111111111111(つまり、42桁の数字と先行ゼロを持つバイナリ表現)が欲しいです。

短い答え:

Python 3.6の新しいf文字列では、非常に簡潔な構文を使用してこれを行うことができます。

>>> f'{0xABC123EFFF:0>42b}'
'001010101111000001001000111110111111111111'

またはそれをセマンティクスで分割する:

>>> number, pad, rjust, size, kind = 0xABC123EFFF, '0', '>', 42, 'b'
>>> f'{number:{pad}{rjust}{size}{kind}}'
'001010101111000001001000111110111111111111'

長い答え:

実際に言っているのは、16進数表現で値があり、同等の値を2進数で表現したいということです。

同値の値は整数です。ただし、文字列で開始することもできます。バイナリで表示するには、文字列で終了する必要があります。

16進数を42桁の2進数と先行ゼロに変換しますか?

スライスを使用したハックなしで、この目標を達成するための直接的な方法がいくつかあります。

まず、バイナリ操作を行う前に、intに変換します(これはリテラルではなく文字列形式であると想定しています)。

>>> integer = int('ABC123EFFF', 16)
>>> integer
737679765503

あるいは、16進数形式で表される整数リテラルを使用することもできます。

>>> 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-stringsによる文字列フォーマット

新しい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ビットを1バイトあたり8ビットで割ると、6バイトになります。

>>> integer.to_bytes(6, 'big')
b'\x00\xab\xc1#\xef\xff'

31
>>> bin( 0xABC123EFFF )

「0b1010101111000001001000111110111111111111」


2
16進数文字列が00で始まる場合、先行ゼロを提供していません
ドラゴン


10

これは、ビット操作を使用してバイナリ文字列を生成するかなり生の方法です。

理解すべき重要な点は次のとおりです。

(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

(どのTBHがどれほど読みやすいかわかりません)


1
これが古いことは知っていますが、「および1」のポイントは正確には何ですか?
Goodies、2015年

三項演算子の前のpythonの昔のものです。(n&(1 << i))はゼロまたはゼロ以外の何かを返します。必要なのは1または0だけなので、それを確実にするために「and 1」が存在します。
John Montgomery

このスクリプトは、テスト用に16進数の暗号秘密鍵をバイナリに変換するのに最適でした。誰かがバイナリ文字列を8ビットのチャンクに分割して出力する方法を知っていますか?すなわち01111001 11111110
エジソン

5

これはGlen Maynardの解決策に少し触れたものであり、それを行う正しい方法だと思います。パディング要素を追加するだけです。


    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

組み込みのformat()関数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

各16進数を対応する4つの2進数に置き換えます。

1 - 0001
2 - 0010
...
a - 1010
b - 1011
...
f - 1111

2
または、16進数の各ペアを対応する2桁の8進数に置き換えるか、16進数の各トリプレットを対応する12桁の2進数に置き換える...または10桁の16進数をそれぞれ40桁のバイナリに置き換える-おっと!元の場所に戻りました。
パビウム2009

2

16進数-> 10進数、次に10進数-> 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')

hex_stringが 'f0'に設定されている場合、これは失敗します
mikemaccana

1

Onedinkenediのソリューションに、埋めるビット数の計算を追加しました。結果の関数は次のとおりです。

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

ここで、16は変換元の基数(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 :-)

短い形式はjoinメソッドです。楽しい。


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の倍数にし、先頭に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でも機能することに注意してください:)


0

モジュールcodenを 使用するだけです(注:私はモジュールの作成者です)

そこで、haxedecimalをバイナリに変換できます。

  1. pipを使用してインストールする
pip install coden
  1. 変換
a_hexadecimal_number = "f1ff"
binary_output = coden.hex_to_bin(a_hexadecimal_number)

変換キーワードは次のとおりです。

  • 六角 hexadeimal用
  • バイナリのビン
  • 10進数の整数
  • _to_-関数の変換キーワード

したがって、次のフォーマットも可能です。hexadecimal_output = 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
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
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.