本文介绍: ASCII 是计算机互联网上最流行的文本数据字符编码格式(美国信息交换标准代码)。ASCII 编码数据中有 128 个额外字母数字特殊控制字符不同值。Python 中不允许使用非 ASCII,因为解释器会将其视为。Python 不能也不应该尝试确定一个字节序列表示 ASCII 范围之外的字符串。要解决错误我们必须在程序顶部添加编码utf-8。

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

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。

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注