我正在学习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 时,所有特殊字符都可以正常工作。
感谢大家的时间和帮助=)