我正在写一些python代码,我收到了标题中的错误消息,从搜索这与字符集有关。

这是导致错误的行

hc = HealthCheck("instance_health", interval=15, target808="HTTP:8080/index.html")

我不知道什么字符不是在ANSI ASCII集?此外,搜索“\xe2”并不能提供关于该字符显示为什么字符的更多信息。这一行中的哪个字符导致了问题?

我还看到了针对这个问题的一些修复程序,但我不确定该使用哪个。有人能澄清什么是问题(python不解释unicode,除非被告知这样做?),以及我将如何正确地清除它?

编辑: 这是出错的那条线附近的所有线

def createLoadBalancer():
    conn = ELBConnection(creds.awsAccessKey, creds.awsSecretKey)
    hc = HealthCheck("instance_health", interval=15, target808="HTTP:8080/index.html")
    lb = conn.create_load_balancer('my_lb', ['us-east-1a', 'us-east-1b'],[(80, 8080, 'http'), (443, 8443, 'tcp')])
    lb.configure_health_check(hc)
    return lb

当前回答

在花了大约半小时的时间查看堆栈溢出后,我突然意识到,如果在注释中使用单引号“'”将会通过错误:

SyntaxError: Non-ASCII character '\xe2' in file

在查看traceback后,我能够找到在我的评论中使用的单引号。

其他回答

我有同样的问题,但这是因为我复制和粘贴字符串,因为它是。 后来,当我手动输入字符串,因为它是错误消失。

我犯了个错误,因为是-号。当我用手动输入代替它时,错误就解决了。

复制字符串10 + 3 * 5/(16−4)

手动输入字符串10 + 3 * 5/(16 - 4)

您可以清楚地看到两个连字符之间有一点不同。

我认为这是因为不同的操作系统使用不同的格式,或者可能只是不同的软件。

我在运行下面简单的.py代码时遇到了这个问题:

import sys
print 'version is:', sys.version

DSM的上述代码提供了以下内容:

1 'print \xe2\x80\x98version is\xe2\x80\x99, sys.version'

所以问题是我的文本编辑器使用了SMART QUOTES,就像John Y建议的那样。在更改文本编辑器设置并重新打开/保存文件后,它可以正常工作。

你会得到一个游离的字节。你可以通过跑步找到它

with open("x.py") as fp:
    for i, line in enumerate(fp):
        if "\xe2" in line:
            print i, repr(line)

你应该用你的程序名替换"x.py"。您将看到行号和有问题的行。例如,在任意插入字节后,我得到:

4 "\xe2        lb = conn.create_load_balancer('my_lb', ['us-east-1a', 'us-east-1b'],[(80, 8080, 'http'), (443, 8443, 'tcp')])\n"

\xe2是'-'字符,它出现在一些复制和粘贴中,它使用了不同的等号'-',导致编码错误。 将'-'(来自复制粘贴)替换为正确的'-'(来自键盘按钮)。

当我在阅读文本文件时遇到类似的问题时,我使用…

f = open('file','rt', errors='ignore')