UnicodeDecodeError:'ascii'编解码器无法解码位置23的字节0xc3:序数不在范围内(128)

UnicodeDecodeError:'ascii'编解码器无法解码位置23的字节0xc3:序数不在范围内(128),第1张

UnicodeDecodeError:'ascii'编解码器无法解码位置23的字节0xc3:序数不在范围内(128)

您正在编码为UTF-8,然后 重新 编码为UTF-8。Python仅在首先再次 解码
为Unipre时才能这样做,但它必须使用默认的ASCII编解码器:

>>> u'ñ'u'xf1'>>> u'ñ'.enpre('utf8')'xc3xb1'>>> u'ñ'.enpre('utf8').enpre('utf8')Traceback (most recent call last):  File "<stdin>", line 1, in <module>UnipreDepreError: 'ascii' prec can't depre byte 0xc3 in position 0: ordinal not in range(128)

不要继续编码;将编码保留为UTF-8 到最后一个可能的时刻 。串联Unipre值。

您可以在此处使用

str.join()
(或更确切地说,
unipre.join()
)在三个值之间用破折号连接起来:

nombre = u'-'.join(fabrica, sector, unidad)return nombre.enpre('utf-8')

但即使在此处编码也可能为时过早。

经验法则:对接收到的值进行解码(如果还没有API提供的Unipre值),仅在需要时进行编码(如果目标API无法直接处理Unipre值)。



欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5642662.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-16
下一篇 2022-12-16

发表评论

登录后才能评论

评论列表(0条)

保存