UnicodeDecodeError,再次使用无效的连续字节

时间:2015-12-25 07:55:34

标签: python unicode utf-8

我无法弄清楚如何一劳永逸地解决这些问题。当我试着写“è”(我是意大利语)时,我第一次遇到这些问题。经过一些研究,我发现在一开始就添加“#coding:utf-8”似乎解决了这个问题......直到现在。

我编辑了1或2天前编写的代码..它工作得很好....现在,每当我运行脚本时,它都不起作用:它永远不会启动,而且我遇到了这个错误:< / p>

SyntaxError: 'utf-8' codec can't decode byte 0xe0 in position 32: invalid continuation byte.

问题是......位置32?哪里?什么是有问题的线?我不知道我添加了什么,因为我做了一些改动。尝试在调试模式下执行也没有帮助,当我在脚本的最开始“Step Into”时,错误立即出现(顺便说一句,我使用的是Wingware 101作为IDLE,我正在使用Win7的)。对不起,如果我没有足够的信息,我可以发布代码,但我害怕这样做,这是一个用意大利语写成的混乱,也许不容易理解到底发生了什么。

感谢您的回复和节日快乐!

1 个答案:

答案 0 :(得分:5)

#coding: utf8声明源代码已保存,采用UTF-8格式。确保它实际上是源文件的编码。例如,以下文件是在Windows记事本中创建的,并保存为“ANSI”,在美国Windows上为Windows-1252编码:

#coding: utf8
print('hàllo')

它在Python 2.7上产生以下错误:

  File "test.py", line 2
SyntaxError: 'utf8' codec can't decode byte 0xe0 in position 8: invalid continuation byte

如您所见,第2行的第8个位置(从0开始计算)为à,其中Windows-1252为字节0xe0。使用了错误的编码,错误消息很明确。

声明源文件的正确编码,或者以UTF-8重新保存源文件。

注意:我没有安装Python 3.4,但Python 3.5提供的错误信息不太清楚:

  File "x.py", line 1
SyntaxError: encoding problem: utf8

但它与您的错误消息不匹配,但仍表示该文件未使用正确的编码声明。