base64.b64enpre()函数的目的是将二进制数据转换为ASCII安全的“文本”
Python不赞成将base64故意归类为二进制转换。
这是Python
3中的一项设计决策,它强制字节和文本分开并禁止隐式转换。Python现在对此非常严格,
bytes.enpre甚至不存在,因此
b'abc'.enpre('base64')会引发
AttributeError。
语言的意见是字节串对象已 被 编码。将字节编码为文本的编解码器不适合此范例,因为当您想从字节域转到文本域时,它是一个 解码
。请注意,出于相同的原因,
rot13编码也从标准编码列表中删除了-不适用于Python 3范例。
可能还有一个性能参数:假设Python自动处理base64输出的解码,该解码是由C代码从模块生成的
ASCII编码二进制表示形式
binascii,转换为文本域中的Python对象。如果您确实需要这些字节,则只需通过再次编码为ASCII来撤消解码。这将是一次浪费的往返,是不必要的双重否定。最好“选择加入”以进行“解码为文本”步骤。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)