Python中文文本分析时遇到的编码问题小结

最近在做python的中文文本分析,万事开头难,最开始就发现了很多中文编码问题,以下对问题进行了汇总。

问题1:中文文本读取时遇到的编码问题

在读取文件后,直接print就会产生问题,如下:

Python中文文本分析时遇到的编码问题小结_第1张图片
解决方案
将字符串进行解码,使用decode()方法,如下:

Python中文文本分析时遇到的编码问题小结_第2张图片
分析与对策
这个问题的根源要说到python2及其以前的版本中的string问题。在python中,有三大类string类型,一种是unicode(text string),一种是str(byte string),第三种是前两者的父类base string。其实,关于一串字节(sequences of bytes)是否应该被当做字符串(string)来处理一直存在着争议,其中java,c#认为不该被当做字符串处理,而python则认为应该当做字符串处理。python认为字节也是字符,所以他们俩的操作集合是一致的,所以在必要的时候,需要对字节进行自动类型转换,例如字节和文本拼接时,于是python就需要一个默认编码来支持两个不同类型之间的自动转换。在python2诞生的年代,ASCII是比较流行的,所以python2的默认编码选择了ASCII。(如今python3已经改成了Unicode,这就意味着做所有的需要转换的场合,都能正确并成功的转换)在不想换版本的情况下,如何解决编码问题呢?首先,尽量保证所有的text string都是unicode类型,如果是str,则可能产生问题;其次,在需要转换的时候,显式转换,从字节解码成文本用decode(),从文本编码成字节用encode();特别低,从外部读取数据时,默认它是字节,需要decode()成需要的文本,就像上例中一样;而当需要向外部发送文本时,encode()成字节再发送。

问题2:python的list要打印出中文的编码问题

pynlpir使用的一个例子

improt pynlpir
pynlpir.open()
s = u'欢迎科研人员、技术工程师、企事业单位与个人参与NLPIR平台的建设工作。'
f = pynlpir.segment(s)
print f

直接print的结果如下:

这里写图片描述
解决方案
导入uniout包(当然其他方法,见相关链接)

  1. pip install uniout
  2. import uniout
  3. 测试,如下:

    Python中文文本分析时遇到的编码问题小结_第3张图片

分析
由于list不属于字符串所以不能直接使用encode()和decode()进行编码或解码,如果一定要使用的话,可以将list转换成str再处理,但是本身处理list中数据最后还是要转换成str处理的,所以要是转换来转换去就显得效率低下,导入uniout是个不错的选择。

参考链接

  1. http://www.cnblogs.com/mingjiatang/p/4890420.html
  2. http://bbs.chinaunix.net/thread-1431029-1-1.html
  3. http://blog.163.com/longsu2010@yeah/blog/static/17361234820113521439979/
  4. http://www.jb51.net/article/75247.htm
  5. http://www.cnblogs.com/fnng/p/5008884.html
  6. http://blog.longwin.com.tw/2014/09/python-list-print-chinese-2014/
  7. http://bbs.csdn.net/topics/391900840
  8. http://python.jobbole.com/81244/

你可能感兴趣的:(问题汇总)