UnicodeDecodeError:'utf8'编解码器无法解码字节0x9c

问题描述 投票:227回答:8

我有一个套接字服务器,应该从客户端接收UTF-8有效字符。

问题是一些客户端(主要是黑客)正在通过它发送所有错误的数据。

我可以很容易地区分真正的客户端,但我正在记录所有发送的数据文件,以便我以后可以分析它。

有时我得到像这个œ这样的字符导致UnicodeDecodeError错误。

我需要能够使用或不使用这些字符来生成字符串UTF-8。


更新:

对于我的特殊情况,套接字服务是一个MTA,因此我只希望接收ASCII命令,如:

EHLO example.com
MAIL FROM: <[email protected]>
...

我用JSON记录了所有这些。

然后一些没有良好意图的人决定出售各种垃圾。

这就是为什么对于我的特定情况,剥离非ASCII字符是完全可以的。

python linux python-unicode
8个回答
300
投票

http://docs.python.org/howto/unicode.html#the-unicode-type

str = unicode(str, errors='replace')

要么

str = unicode(str, errors='ignore')

注意:这将删除(忽略)有问题的字符,返回没有它们的字符串。

对我来说,这是理想的情况,因为我使用它作为非ASCII输入的保护,这是我的应用程序不允许的。

或者:使用codecs模块中的open方法读入文件:

import codecs
with codecs.open(file_name, 'r', encoding='utf-8',
                 errors='ignore') as fdata:

50
投票

现在我已经转移到Python 3,这种类型的问题突然出现了。我不知道Python 2只是简单地推动了文件编码的任何问题。

我找到了这个差异的很好的解释,以及如何找到解决方案,因为上述任何一个都没有。

http://python-notes.curiousefficiency.org/en/latest/python3/text_file_processing.html

简而言之,要使Python 3的行为与Python 2尽可能相似,请使用:

with open(filename, encoding="latin-1") as datafile:
    # work on datafile here

但是,阅读文章,没有一个适合所有解决方案。


50
投票

将引擎从C更改为Python对我来说是个窍门。

引擎是C:

pd.read_csv(gdp_path, sep='\t', engine='c')

'utf-8'编解码器无法解码位置18中的字节0x92:无效的起始字节

引擎是Python:

pd.read_csv(gdp_path, sep='\t', engine='python')

对我没有错误。


28
投票
>>> '\x9c'.decode('cp1252')
u'\u0153'
>>> print '\x9c'.decode('cp1252')
œ

18
投票

我和UnicodeDecodeError有同样的问题,我用这条线解决了。不知道是否是最好的方式,但它对我有用。

str = str.decode('unicode_escape').encode('utf-8')

2
投票

以防万一有同样的问题。我正在使用vim与YouCompleteMe,没有用这个错误消息启动ycmd,我做的是:export LC_CTYPE="en_US.UTF-8",问题消失了。


2
投票

第一个,使用get_encoding_type获取编码的文件类型:

import os    
from chardet import detect

# get file encoding type
def get_encoding_type(file):
    with open(file, 'rb') as f:
        rawdata = f.read()
    return detect(rawdata)['encoding']

第二,用类型打开文件:

open(current_file, 'r', encoding = get_encoding_type, errors='ignore')

0
投票

如果您需要对文件进行更改但不知道文件的编码,您可以做什么?如果您知道编码是ASCII兼容的并且只想检查或修改ASCII部分,则可以使用surrogateescape错误处理程序打开该文件:

with open(fname, 'r', encoding="ascii", errors="surrogateescape") as f:
    data = f.read()
© www.soinside.com 2019 - 2024. All rights reserved.