0

我编写了一个脚本,它读取 .cnf 文件,分析一些内容,然后输出一些结果(通过print())。为了读取 .cnf 文件,我使用以下行:

with open('config.cnf') as f:
file_content = f.read()

现在,如果我在 Spyder 环境(Python 3.6)中运行它,一切正常。脚本读取 config.cnf,执行操作并输出结果。如果我在 Linux 上运行完全相同的脚本(config.cnf 位于同一目录中),则会显示以下错误消息:

Traceback (most recent call last):
  File "Conf2Monit_V2.py", line 45, in <module>
    file_content = f.read()
  File "/usr/lib/python3.6/codecs.py", line 321, in decode
    (result, consumed) = self._buffer_decode(data, self.errors, final)
UnicodeDecodeError: 'utf-8' codec can't decode byte 0x96 in Position 29834: invalid start byte

我使用以下命令:

python3 myScript.py 

我是 Python 和 Linux 的新手,所以如果这是一些基本错误,请不要厌倦。谢谢你。

4

2 回答 2

0

我猜这个问题可能是因为不同平台的不同线路结束的历史原因

如果是这种情况,请尝试一下

否则你可以试试 Linux 的 iconv 命令。

您能否通过在 Linux 环境中运行以下命令来检查文件中字符的编码:

file -i <filename>

检查输出是否类似于charset=utf-8

如果没有,有一种方法可以将编码转换为 UTF-8,如下所示

它解释了如何将文件(“input.txt”)的编码从代码集 ISO88592 转换为 UTF8 代码集或 ASCII 并将结果存储为“output.txt”。

iconv -f ISO88592 -t UTF8 input.txt output.txt

因此,如果正在考虑的文件是 input.txt,您可能要遵循的步骤是:

  1. file -i input.txt
    ,假设它的输出类似于
    input.txt: text/plain; 字符集=iso-88592
  2. iconv -f ISO88592 -t UTF8 input.txt output.txt
于 2019-04-29T09:10:55.250 回答
0

解决方案很简单:

我在 Windows 编辑器中打开了该文件。然后在“另存为...”下,我能够将底部的设置从“ASCII”更改为“UTF-8”。然后我将文件传输回我的 Linux 系统等等。工作。

于 2019-04-29T12:54:31.670 回答