繁体   English   中英

如何将base64解码为单个字节?

[英]How to decode base64 to single bytes?

在以下代码中:

import base64
base64.decodebytes('DBCCOAABAMA='.encode('ascii'))

结果是

b'\x0c\x10\x828\x00\x01\x00\xc0'

第三个字节是\\x828 ,它不适合单个字节并导致我的脚本出现问题。 我不想将它解码为ASCII以外的任何东西。

初始base64编码器有什么问题吗? 为什么会发生这个问题,我该如何解决?


更新:

我面临的问题是代码

base64.decodebytes('DBCCOAABAMA='.encode('ascii')).decode('ascii')

导致错误

UnicodeDecodeError: 'ascii' codec can't decode byte 0x82 in position 2: ordinal not in range(128)

某些字节,如果它们落在可打印字符范围内,则不会以十六进制转义形式打印。 这段代码向您展示了真正发生的事情:

>>> for b in base64.decodebytes('DBCCOAABAMA='.encode('ascii')):
    print(hex(b), chr(b))

0xc 
0x10 
0x82 ‚
0x38 8
0x0 
0x1 
0x0 
0xc0 À

PS 我不明白为什么encode没有抛出错误,其中一些字节超出了 ASCII 范围。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM