Python 文件错误 SyntaxError: Non-Ascii Character \xe2

此错误表明您正在代码中写入非 ASCII 字符。 在编译时,解释器感到困惑并抛出 SyntaxError: Non-ASCII character ‘\xe2’

ASCII 字符使用与 UTF-8 的前 128 个字符相同的编码,因此 ASCII 文本与 UTF-8 兼容。 首先,您必须了解 ASCII 字符和非 ASCII 字符之间的区别。


什么是 ASCII 码

ASCII 是计算机和互联网上最流行的文本数据字符编码格式(美国信息交换标准代码)。

ASCII 编码数据中有 128 个额外的字母、数字、特殊和控制字符的不同值。


Python 中错误 SyntaxError: Non-ASCII character ‘\xe2’

此错误背后的核心原因是您正在读取 Python 编译器无法识别的字符。

例如,让我们试试 Python 解释器无法识别的符号 £。

string = "£"
fp = open("test.txt", "w+")

fp.write("%s" % string)
print(string)

输出:

SyntaxError: Non-ASCII character '\xe2'

符号 £ 无法被解释器识别,因此它会给出 SyntaxError: Non-ASCII character ‘\xe2’。


如何修复语法错误:Python 文件中的非 ASCII 字符 ‘\xe2’

在这里,我们在程序的顶部包含了#coding: utf-8 语句。 此代码将创建一个文件 test.txt,其中存储了 £ 值,并将打印在输出中,如图所示。

代码示例:

# coding: utf-8
string = "£"
fp = open("test.txt", "w+")

fp.write("%s" % string)
print(string)

输出:

£

阅读错误提供的 PEP,它说 £ 不是 ASCII 字符,尽管您的代码尝试使用它。 如果可以,请使用 UTF-8 编码,并将 # coding: utf-8 放在程序的顶部以开始使用。

为了变得更复杂,您甚至可以在代码中逐个字符串地声明编码。 但是,如果您尝试将 £ 文字添加到您的代码中,则需要一个在整个文件中支持它的编码器。

您还可以添加下面给出的代码行。

#!/usr/bin/env python
# -*- coding: utf-8 -*-

总结

Python 中不允许使用非 ASCII,因为解释器会将其视为 SyntaxError。 Python 不能也不应该尝试确定一个字节序列表示 ASCII 范围之外的字符串。

要解决此错误,我们必须在程序顶部添加编码:utf-8。

猜你喜欢

转载自blog.csdn.net/fengqianlang/article/details/134741322