将二进制转换为 ASCII 或将 ASCII 转换为二进制

2024-12-17 08:30:00
admin
原创
135
摘要:问题描述:使用此代码获取字符串并将其转换为二进制:bin(reduce(lambda x, y: 256*x+y, (ord(c) for c in 'hello'), 0)) 输出:0b110100001100101011011000110110001101111 如果我把它放到这个网站(在右侧网站)中,我...

问题描述:

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

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

输出:

0b110100001100101011011000110110001101111

如果我把它放到这个网站(在右侧网站)中,我就会收到回复hello。我想知道它使用什么方法。我知道我可以将二进制字符串拆分成 8 个字节,然后将其与相应的值匹配bin(ord(character)),或者其他方法。真的在寻找更简单的东西。


解决方案 1:

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

>>> import binascii
>>> bin(int(binascii.hexlify('hello'), 16))
'0b110100001100101011011000110110001101111'

相反:

>>> n = int('0b110100001100101011011000110110001101111', 2)
>>> binascii.unhexlify('%x' % n)
'hello'

在 Python 3.2+ 中:

>>> bin(int.from_bytes('hello'.encode(), 'big'))
'0b110100001100101011011000110110001101111'

相反:

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

为了支持 Python 3 中的所有 Unicode 字符:

def text_to_bits(text, encoding='utf-8', errors='surrogatepass'):
    bits = bin(int.from_bytes(text.encode(encoding, errors), 'big'))[2:]
    return bits.zfill(8 * ((len(bits) + 7) // 8))

def text_from_bits(bits, encoding='utf-8', errors='surrogatepass'):
    n = int(bits, 2)
    return n.to_bytes((n.bit_length() + 7) // 8, 'big').decode(encoding, errors) or ''

这是单源 Python 2/3 兼容版本:

import binascii

def text_to_bits(text, encoding='utf-8', errors='surrogatepass'):
    bits = bin(int(binascii.hexlify(text.encode(encoding, errors)), 16))[2:]
    return bits.zfill(8 * ((len(bits) + 7) // 8))

def text_from_bits(bits, encoding='utf-8', errors='surrogatepass'):
    n = int(bits, 2)
    return int2bytes(n).decode(encoding, errors)

def int2bytes(i):
    hex_string = '%x' % i
    n = len(hex_string)
    return binascii.unhexlify(hex_string.zfill(n + (n & 1)))

例子

>>> text_to_bits('hello')
'0110100001100101011011000110110001101111'
>>> text_from_bits('110100001100101011011000110110001101111') == u'hello'
True

解决方案 2:

仅限内置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 '
List of Bits:'
for x in b:
    print x

print '
String:'
print s2

String:
Hello, World!

List of Bits:
01001000
01100101
01101100
01101100
01101111
00101100
00100000
01010111
01101111
01110010
01101100
01100100
00100001

String:
Hello, World!

解决方案 3:

我不确定您认为除了逐个字符执行之外还能如何执行此操作 —— 这本质上是一个逐个字符的操作。 当然有代码可以为您执行此操作,但没有比逐个字符执行此操作更“简单”的方法了。

首先,需要去掉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)

如果您确实想将其视为一个数字,那么您仍然必须考虑到这样一个事实:如果您想从左到右而不是从右到左,最左边的字符最多有七位数字。

解决方案 4:

这是我解决你的任务的方法:

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

解决方案 5:

如果您不想导入任何文件,您可以使用以下命令:

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 发送。

解决方案 6:

您是否正在寻找执行此操作的代码或了解算法?

这能满足您的需要吗?具体来说a2b_uub2a_uu还有许多其他选项,以防这些不是您想要的。

(注意:我不是 Python 爱好者,但这似乎是一个显而易见的答案)

解决方案 7:

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

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="")

解决方案 8:

这是 JF Sebastian 的精简版。不过还是要感谢 JF Sebastian 提供的片段。

import binascii, sys
def goodbye():
    sys.exit("
"+"*"*43+"

Good Bye! Come use again!

"+"*"*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:
>>> ')
        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 '
'+'*'*84+'

'+convert+'

'+'*'*84+'
'
    if var1=='b':
        binary=raw_input('Binary to convert:
>>> ')
        n = int(binary, 2)
        done=binascii.unhexlify('%x' % n)
        print '
'+'*'*84+'

'+done+'

'+'*'*84+'
'
    if var1=='e':
        aus=raw_input('Are you sure? (y/n)
>>> ')
        if aus=='y':
            goodbye()
相关推荐
  政府信创国产化的10大政策解读一、信创国产化的背景与意义信创国产化,即信息技术应用创新国产化,是当前中国信息技术领域的一个重要发展方向。其核心在于通过自主研发和创新,实现信息技术应用的自主可控,减少对外部技术的依赖,并规避潜在的技术制裁和风险。随着全球信息技术竞争的加剧,以及某些国家对中国在科技领域的打压,信创国产化显...
工程项目管理   1579  
  为什么项目管理通常仍然耗时且低效?您是否还在反复更新电子表格、淹没在便利贴中并参加每周更新会议?这确实是耗费时间和精力。借助软件工具的帮助,您可以一目了然地全面了解您的项目。如今,国内外有足够多优秀的项目管理软件可以帮助您掌控每个项目。什么是项目管理软件?项目管理软件是广泛行业用于项目规划、资源分配和调度的软件。它使项...
项目管理软件   1355  
  信创产品在政府采购中的占比分析随着信息技术的飞速发展以及国家对信息安全重视程度的不断提高,信创产业应运而生并迅速崛起。信创,即信息技术应用创新,旨在实现信息技术领域的自主可控,减少对国外技术的依赖,保障国家信息安全。政府采购作为推动信创产业发展的重要力量,其对信创产品的采购占比情况备受关注。这不仅关系到信创产业的发展前...
信创和国产化的区别   8  
  信创,即信息技术应用创新产业,旨在实现信息技术领域的自主可控,摆脱对国外技术的依赖。近年来,国货国用信创发展势头迅猛,在诸多领域取得了显著成果。这一发展趋势对科技创新产生了深远的推动作用,不仅提升了我国在信息技术领域的自主创新能力,还为经济社会的数字化转型提供了坚实支撑。信创推动核心技术突破信创产业的发展促使企业和科研...
信创工作   9  
  信创技术,即信息技术应用创新产业,旨在实现信息技术领域的自主可控与安全可靠。近年来,信创技术发展迅猛,对中小企业产生了深远的影响,带来了诸多不可忽视的价值。在数字化转型的浪潮中,中小企业面临着激烈的市场竞争和复杂多变的环境,信创技术的出现为它们提供了新的发展机遇和支撑。信创技术对中小企业的影响技术架构变革信创技术促使中...
信创国产化   8  
热门文章
项目管理软件有哪些?
云禅道AD
禅道项目管理软件

云端的项目管理软件

尊享禅道项目软件收费版功能

无需维护,随时随地协同办公

内置subversion和git源码管理

每天备份,随时转为私有部署

免费试用