将二进制转换为ASCII,反之亦然使用此代码获取字符串并将其转换为二进制:bin(reduce(lambda x, y: 256*x+y, (ord(c) for c in 'hello'), 0))这一产出:0b110100001100101011011000110110001101111如果我把它放进去本站(在右边的网站)我收到hello背。我想知道它用的是什么方法。我知道我可以将二进制字符串分割成8,然后将其与相应的值匹配。bin(ord(character))或者其他方式。真的在寻找更简单的东西。
3 回答

潇潇雨雨
TA贡献1833条经验 获得超4个赞
[ -~]
>>> import binascii>>> bin(int(binascii.hexlify('hello'), 16))'0b110100001100101011011000110110001101111'
>>> n = int('0b110100001100101011011000110110001101111', 2)>>> binascii.unhexlify('%x' % n)'hello'
>>> 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 '\0'
下面是单源Python 2/3兼容版本:
import binasciidef 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

元芳怎么了
TA贡献1798条经验 获得超7个赞
0b
bitstring = bitstring[2:]bitstring = -len(bitstring) % 8 * '0' + bitstring
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)
添加回答
举报
0/150
提交
取消