gpt4 book ai didi

Python 3 如何在将 UTF-8 写入文件时忽略错误

转载 作者:行者123 更新时间:2023-11-30 22:36:14 34 4
gpt4 key购买 nike

我有以下程序:

with open(r'C:\s_f.csv', 'w', encoding="utf-8", errors="ignore") as outf:
with open(r'C:\street.csv', 'r', encoding="utf-8", errors="ignore") as f:
for line in f:
out_line = line
out_line = out_line.replace('"','¬')
out_line = out_line.replace(',','~')
outf.write(out_line)

出于某种原因,我仍然得到:

File "c:\Program Files\Anaconda3\streets.py", line 5
SyntaxError: Non-UTF-8 code starting with '\xac' in file c:\Program Files\Anaconda3\streets.py on line 5, but no encoding declared; see http://python.org/dev/peps/pep-0263/ for details

如何忽略 Python 3 中的 UTF-8 错误?

最佳答案

您已将源代码保存为 UTF-8 以外的格式,很可能是 Latin-1 或 Windows 代码页 1252。

您的选择是更改源代码使用的编码(使用文本编辑器),在源文件的第一行或第二行声明源代码编码(如错误消息所示),或使用 ASCII 安全的编码转义序列。

后者可以通过使用 \xhh\uhhhh 转义序列来完成:

out_line = out_line.replace('"','\xAC')  # or `'\u00AC'`

\xac\x00ac(不区分大小写)在 Unicode 标准中对相同字符进行编码,即 U+00AC NOT SIGN codepoint 。如果正确编码为 UTF-8,则将使用 C2 AC 字节序列,但您的 .py 文件是使用 AC 保存的仅在那时

如果您确实知道所使用的编码但不想更改它,请添加 PEP 263 comment到文件的开头(顶部的第一行或第二行):

# coding=cp1252

但是,最佳选项是将代码编辑器配置为将文件保存为 UTF-8。这是 Python 3 用来读取源代码的默认编码。

这与写入 CSV 文件无关,Python 甚至无法开始运行您的代码,因为它无法正确读取源代码。

关于Python 3 如何在将 UTF-8 写入文件时忽略错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44258329/

34 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com