Python 将二进制转换为ASCII,反之亦然

Python 将二进制转换为ASCII,反之亦然,python,binary,ascii,Python,Binary,Ascii,使用此代码获取字符串并将其转换为二进制: bin(reduce(lambda x, y: 256*x+y, (ord(c) for c in 'hello'), 0)) 这将产生: 0b110100001100101011011000110110001101111 如果我把它放在(右边的网站上),我会收到我的hello信息。我想知道它用什么方法。我知道我可以将二进制字符串拼接成8,然后将其与对应的值匹配到bin(ord(character))或其他方式。真的在寻找更简单的东西。你是在寻找代码

使用此代码获取字符串并将其转换为二进制:

bin(reduce(lambda x, y: 256*x+y, (ord(c) for c in 'hello'), 0))
这将产生:

0b110100001100101011011000110110001101111

如果我把它放在(右边的网站上),我会收到我的
hello
信息。我想知道它用什么方法。我知道我可以将二进制字符串拼接成8,然后将其与对应的值匹配到
bin(ord(character))
或其他方式。真的在寻找更简单的东西。

你是在寻找代码来做这件事还是理解算法

??特别是
a2b_uu
b2a_uu
?如果这些不是你想要的,还有很多其他的选择


(注意:不是Python的家伙,但这似乎是一个显而易见的答案)

我不确定你认为除了一个字符一个字符的操作之外,你还能做什么——它本质上是一个字符一个字符的操作。当然有一些代码可以为您实现这一点,但没有比逐个字符实现更“简单”的方法了

k=7
dec=0
new=[]
item=[x for x in input("Enter 8bit binary number with , seprator").split(",")]
for i in item:
    for j in i:
        if(j=="1"):
            dec=2**k+dec
            k=k-1
        else:
            k=k-1
    new.append(dec)
    dec=0
    k=7
print(new)
for i in new:
    print(chr(i),end="")
首先,您需要去掉
0b
前缀,并将字符串保留为零,使其长度可被8整除,以便于将位字符串拆分为字符:

bitstring = bitstring[2:]
bitstring = -len(bitstring) % 8 * '0' + bitstring
然后将字符串分成八个二进制数字块,将它们转换为ASCII字符,然后将它们重新连接成字符串:

string_blocks = (bitstring[i:i+8] for i in range(0, len(bitstring), 8))
string = ''.join(chr(int(char, 2)) for char in string_blocks)

如果您确实想将其视为一个数字,您仍然必须考虑这样一个事实,即如果您想从左向右而不是从右向左,则最左边的字符长度最多为七位。

对于Python 2上范围
[-~]
内的ASCII字符:

>>> import binascii
>>> bin(int(binascii.hexlify('hello'), 16))
'0b110100001100101011011000110110001101111'
反过来说:

>>> n = int('0b110100001100101011011000110110001101111', 2)
>>> binascii.unhexlify('%x' % n)
'hello'
>>> n = int('0b110100001100101011011000110110001101111', 2)
>>> n.to_bytes((n.bit_length() + 7) // 8, 'big').decode()
'hello'

在Python 3.2+中:

>>> bin(int.from_bytes('hello'.encode(), 'big'))
'0b110100001100101011011000110110001101111'
反过来说:

>>> n = int('0b110100001100101011011000110110001101111', 2)
>>> binascii.unhexlify('%x' % n)
'hello'
>>> n = int('0b110100001100101011011000110110001101111', 2)
>>> n.to_bytes((n.bit_length() + 7) // 8, 'big').decode()
'hello'

要支持Python 3中的所有Unicode字符,请执行以下操作: 以下是与Python 2/3兼容的单源版本: 例子
这是我解决您任务的方法:

str = "0b110100001100101011011000110110001101111"
str = "0" + str[2:]
message = ""
while str != "":
    i = chr(int(str[:8], 2))
    message = message + i
    str = str[8:]
print message

这是J.F.塞巴斯蒂安的打扮版。感谢J.F.塞巴斯蒂安的片段

import binascii, sys
def goodbye():
    sys.exit("\n"+"*"*43+"\n\nGood Bye! Come use again!\n\n"+"*"*43+"")
while __name__=='__main__':
    print "[A]scii to Binary, [B]inary to Ascii, or [E]xit:"
    var1=raw_input('>>> ')
    if var1=='a':
        string=raw_input('String to convert:\n>>> ')
        convert=bin(int(binascii.hexlify(string), 16))
        i=2
        truebin=[]
        while i!=len(convert):
            truebin.append(convert[i])
            i=i+1
        convert=''.join(truebin)
        print '\n'+'*'*84+'\n\n'+convert+'\n\n'+'*'*84+'\n'
    if var1=='b':
        binary=raw_input('Binary to convert:\n>>> ')
        n = int(binary, 2)
        done=binascii.unhexlify('%x' % n)
        print '\n'+'*'*84+'\n\n'+done+'\n\n'+'*'*84+'\n'
    if var1=='e':
        aus=raw_input('Are you sure? (y/n)\n>>> ')
        if aus=='y':
            goodbye()

如果不想导入任何文件,可以使用以下方法:

with open("Test1.txt", "r") as File1:
St = (' '.join(format(ord(x), 'b') for x in File1.read()))
StrList = St.split(" ")
将文本文件转换为二进制文件

您可以使用它将其转换回字符串:

StrOrgList = StrOrgMsg.split(" ")


for StrValue in StrOrgList:
    if(StrValue != ""):
        StrMsg += chr(int(str(StrValue),2))
print(StrMsg)
希望这是有帮助的,我已经使用了一些自定义加密通过TCP发送

仅内置
python
这是一个用于简单字符串的纯python方法,留待后人使用

def string2bits(s=''):
    return [bin(ord(x))[2:].zfill(8) for x in s]

def bits2string(b=None):
    return ''.join([chr(int(x, 2)) for x in b])

s = 'Hello, World!'
b = string2bits(s)
s2 = bits2string(b)

print 'String:'
print s

print '\nList of Bits:'
for x in b:
    print x

print '\nString:'
print s2


将二进制文件转换为其等效字符

k=7
dec=0
new=[]
item=[x for x in input("Enter 8bit binary number with , seprator").split(",")]
for i in item:
    for j in i:
        if(j=="1"):
            dec=2**k+dec
            k=k-1
        else:
            k=k-1
    new.append(dec)
    dec=0
    k=7
print(new)
for i in new:
    print(chr(i),end="")

我已经研究了一段时间了,binascii不为我工作,主要是寻找代码,如果我能看到它,我就能理解它。通过编辑谢谢:当使用binascii a2b_uu将ascii转换为二进制时,“h”是\x00\x00\x00\x00\x00\x00\x00\x00这不是我需要的,我需要的是“hello”和实际的1和0不是外壳代码形式的ascii,而且它只通过字符工作char@Jaxidian这对我的目的很有帮助。有人在字符串中存储了一些数据,我有它。我很确定这是一个64位二进制b/c的填充。我可以在此基础上成功地使用
b2a_base64
,但结果确实令人困惑。如何从中获取布尔数/整数(0,1)列表?您的问题也是“有没有比显而易见的更简洁的方法来反转我的代码?”相关:允许创建二进制字符串(
“01”
)直接从bytestrings创建,而不创建中间Python整数。@J.F.Sebastian我在Python当前版本中尝试了此方法,但似乎不起作用
TypeError:“str”不支持缓冲区接口
是否更新answer@hamza:它在Python 2上工作。在Python 3上,您应该首先将str转换为字节,例如,
您的_字符串。encode('ascii','strict')
@J.F.Sebasitian:谢谢,但是当我尝试使用它时,反之亦然,unexlify函数返回一条错误消息:binascii。错误:奇数长度字符串。@hamza:如果十六进制字符串的长度不是偶数,则在它前面加上
'0'
。如果原始字符串中的第一个字符的ascii码小于16,则会发生这种情况,例如,
'\n'
'\t'
。ascii字母不会出现奇数长度
[-~]
。为什么要在str=“0”+str[2:]处添加“0”?。需要在此处删除0b,因为它正在开始。chr(int())正是我要找的!也正是我想要的!!
k=7
dec=0
new=[]
item=[x for x in input("Enter 8bit binary number with , seprator").split(",")]
for i in item:
    for j in i:
        if(j=="1"):
            dec=2**k+dec
            k=k-1
        else:
            k=k-1
    new.append(dec)
    dec=0
    k=7
print(new)
for i in new:
    print(chr(i),end="")