我无法弄清楚如何一劳永逸地解决这些问题。当我试着写“è”(我是意大利语)时,我第一次遇到这些问题。经过一些研究,我发现在一开始就添加“#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的)。对不起,如果我没有足够的信息,我可以发布代码,但我害怕这样做,这是一个用意大利语写成的混乱,也许不容易理解到底发生了什么。
感谢您的回复和节日快乐!
答案 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
但它与您的错误消息不匹配,但仍表示该文件未使用正确的编码声明。