Windows 命令行下解决python utf-8中文输出的终极解决方案!

代码参考了这里:http://wiki.python.org/moin/PrintFails

上文对各种系统无法输出奇葩编码的字符做了总结,本文中只针对windows cmd下GBK编码(cp936)但想执行utf-8编码的python文件进行修改。


原理就是:

Another is to put an intercept between sys.stdout, and the text wrapper.

更多还是看参考文章吧,这里直接贴代码:


[python]  view plain  copy
  1. # -*- coding: utf-8 -*-  
  2. import sys  
  3.   
  4. class UnicodeStreamFilter:  
  5.     def __init__(self, target):  
  6.         self.target = target  
  7.         self.encoding = 'utf-8'  
  8.         self.errors = 'replace'  
  9.         self.encode_to = self.target.encoding  
  10.     def write(self, s):  
  11.         if type(s) == str:  
  12.             s = s.decode("utf-8")  
  13.         s = s.encode(self.encode_to, self.errors).decode(self.encode_to)  
  14.         self.target.write(s)  
  15.           
  16. if sys.stdout.encoding == 'cp936':  
  17.     sys.stdout = UnicodeStreamFilter(sys.stdout)  
  18.   
  19. if __name__ == "__main__":      
  20.     a = "你好"  
  21.     b = u"你好"  
  22.     print a  
  23.     print b  

保存成一个py文件,直接import即可。

这样就实现了linux下和windows下兼容了~

当然如果不知道原来是什么编码,但想转成utf-8编码的话,将上面的if条件删掉即可。

你可能感兴趣的:(python,python,utf-8,编码)