我试图让一个Python 3程序对一个充满信息的文本文件做一些操作。然而,当我试图读取文件时,我得到以下错误:

Traceback (most recent call last):  
   File "SCRIPT LOCATION", line NUMBER, in <module>  
     text = file.read()
   File "C:\Python31\lib\encodings\cp1252.py", line 23, in decode  
     return codecs.charmap_decode(input,self.errors,decoding_table)[0]
UnicodeDecodeError: 'charmap' codec can't decode byte 0x90 in position 2907500: character maps to `<undefined>`  

当前回答

不要再浪费你的时间了,只要在读写代码中添加以下encoding="cp437"和errors='ignore'即可:

open('filename.csv', encoding="cp437", errors='ignore')
open(file_name, 'w', newline='', encoding="cp437", errors='ignore')

祝成功

其他回答

对我来说,改变Mysql字符编码一样,我的代码有助于整理出解决方案。照片=开放(pic3.png,编码= latin1)中的一个

对于那些在Windows中开发Anaconda的人,我也遇到了同样的问题。notepad++帮我解决它。

在notepad++中打开文件。在右下方,它会告诉你当前的文件编码。 在顶部菜单中,在“视图”旁边找到“编码”。在“编码”转到“字符集”,耐心地寻找你需要的编码。在我的例子中,编码“Windows-1252”在“西欧”下找到了

该文件没有使用CP1252编码。它使用了另一种编码。哪一个你得自己想清楚。常见的是Latin-1和UTF-8。由于在Latin-1中0x90实际上没有任何含义,因此更可能是UTF-8(其中0x90是一个延续字节)。

打开文件时指定编码:

file = open(filename, encoding="utf8")

作为@LennartRegebro回答的延伸:

如果你不知道你的文件使用的是什么编码,上面的解决方案也不起作用(不是utf8),你发现自己只是在猜测——有一些在线工具可以用来识别那是什么编码。它们并不完美,但通常都能正常工作。在你弄清楚编码之后,你应该能够使用上面的解决方案。

编辑:(摘自评论)

一个非常流行的文本编辑器Sublime text有一个命令来显示编码,如果它已设置…

进入视图->显示控制台(或Ctrl+ ')

在底部view.encoding()输入字段,并希望最好的(我无法得到任何东西,但未定义,但也许你会有更好的运气…)

在Python的新版本(从3.7开始)中,您可以添加解释器选项-Xutf8,这应该可以解决您的问题。如果你使用Pycharm,只需运行>编辑配置(在选项卡配置更改值字段解释器选项-Xutf8)。

或者,同样地,您可以将环境变量PYTHONUTF8设置为1。