3

我正在学习Python并尝试制作一个挂机游戏(直译-不知道游戏的英文真实名称。对不起。)。对于不熟悉这个游戏的人来说,玩家必须通过一次猜一个字母来发现一个秘密单词。

在我的代码中,我使用以下代码从 txt 文件中导入了一组密语:

words_bank = open('palavras.txt', 'r')
words = []
for line in words_bank:
  words.append(line.strip().lower())
words_bank.close()
print(words)

的输出print(words)是,['ma\xc3\xa7\xc3\xa3', 'a\xc3\xa7a\xc3\xad', 'tucum\xc3\xa3']但如果我尝试print('maçã, açaí, tucumã')检查特殊字符,一切都会正确打印。看起来问题出在编码(或解码......我仍在阅读很多关于它的文章以真正理解)文件中的特殊字符。

我的代码第 1 行的内容是# coding: utf-8因为经过一些研究,我发现我必须指定要编码/解码的文本所需的 Unicode 格式。在添加之前,我在运行代码时收到以下消息:

File "path/forca.py", line 12
SyntaxError: Non-ASCII character '\xc3' in file path/forca.py on line 12, but no encoding declared

第 12 行内容:print('maçã, açaí, tucumã')

我已经尝试过的事情:

  • 添加encode='utf-8'为参数open('palavras.txt', 'r')
  • 添加decode='utf-8'为参数open('palavras.txt', 'r')
  • 与上述相同,但使用 latin1
  • 将第 1 行内容替换为#coding: latin1

我的操作系统是 Ubuntu 20.04 LTS,我的 IDE 是 VS Code。没有任何作用!我不知道什么搜索和做什么了。

解决方案在这里

感谢上面朋友的帮助,我发现真正的问题出在 Ubuntu 20.04 LTS 的组合 VS Code 扩展(Code Runner)+ python 别名版本中。

在我的情况下,Code Runner 设置为在终端中运行代码,所以显然,当它调用 python 时,别名版本是python 2.7.x. 为了克服这种情况,我使用这个线程将 python 3 设置为默认值。

完成!每当在终端和带有 Code Runner 的 VS Code 中调用 python 时,所有特殊字符都可以正常工作。

感谢大家的时间和帮助=)

4

1 回答 1

1

这仅在使用Python 2.x时发生。

该错误可能是因为您正在打印列表而不是打印列表中的项目。

当调用print(words)(words是一个列表) 时,Python 调用一个repr在列表对象上调用的特殊函数。然后,该列表通过调用列表repr中的每个子项来创建列表的摘要表示,然后创建一个整洁的字符串可视化。

repr(string)实际上返回一个 ASCII 表示(带有转义)而不是适合您终端的版本。

相反,请尝试:

for x in words:
    print(x)

笔记。的选项openencoding。例如

open('myfile.txt', encoding='utf-8')

您应该始终传递encoding打开选项 - Linux 和 Mac 上的 Python <=3.8 将采用 UTF-8(对于大多数人而言)。Windows 上的 Python <=3.8 将使用 8 位代码页。Python 3.9 将始终使用 UTF-8

请参阅 Python 2.x 与 3.x 的行为:

py2

>>> print ['maçã', 'açaí', 'tucumã']
['ma\xc3\xa7\xc3\xa3', 'a\xc3\xa7a\xc3\xad', 'tucum\xc3\xa3']
>>> repr('maçã')
"'ma\\xc3\\xa7\\xc3\\xa3'"
>>> print 'maçã'
maçã

py3

>>> print(['maçã', 'açaí', 'tucumã'])
['maçã', 'açaí', 'tucumã']
>>> repr('maçã')
"'maçã'"
于 2020-12-16T13:45:41.717 回答