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

错误表明您正在代码中写入非 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。

原文地址:https://blog.csdn.net/fengqianlang/article/details/134741322

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_35140.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

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