Python读取中文txt文件错误:UnicodeEncodeError: 'gbk' codec can't encode character

Posted morein2008

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Python读取中文txt文件错误:UnicodeEncodeError: 'gbk' codec can't encode character相关的知识,希望对你有一定的参考价值。

1   with open(file,r) as f:
2         line=f.readline()
3         i=1
4         while line:
5             line=line.decode(utf-8)
6             print str(i)+":   "+line7             line=f.readline() 
8             i=i+1

用以上代码读取一个包含中文的txt文件时,在正确地读取并打印了六百多行之后,print str(i)+": "+line这一行报错:

UnicodeEncodeError: ‘gbk‘ codec can‘t encode character u‘\u200b‘ in position 99: illegal multibyte sequence

上网查到http://www.crifan.com/unicodeencodeerror_gbk_codec_can_not_encode_character_in_position_illegal_multibyte_sequence/

据分析,上述代码先decode方法将中文字符转为unicode编码,然后print语句打印时,会将其以默认的gbk进行编码,前六百多行能正确打印,说明能够正常编码成gbk,但存在部分字符不能用gbk编码,改用比gbk更大的字符集gb18030之后就没问题了:

1 print str(i)+": "+line

改为:

1 print str(i)+"   "+line.encode(gb18030)

 

以上是关于Python读取中文txt文件错误:UnicodeEncodeError: 'gbk' codec can't encode character的主要内容,如果未能解决你的问题,请参考以下文章

JAVA 中文 unicode 相互转换 文件读取

Python读取中文txt文件错误:UnicodeEncodeError: 'gbk' codec can't encode character

Python中读取txt文本出现:SyntaxError: (unicode error) 'unicodeescape' codec can't decode bytes i

MFC - CStdioFile 读取txt文件UNICODE 中文异常

Python中读取txt文本出现:SyntaxError: (unicode error) 'unicodeescape' codec can't decode bytes i

python2 将TXT文本转码为utf-8