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.

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


# -*- coding: utf-8 -*-
import sys

class UnicodeStreamFilter:
    def __init__(self, target):
        self.target = target
        self.encoding = 'utf-8'
        self.errors = 'replace'
        self.encode_to = self.target.encoding
    def write(self, s):
        if type(s) == str:
            s = s.decode("utf-8")
        s = s.encode(self.encode_to, self.errors).decode(self.encode_to)
        self.target.write(s)
        
if sys.stdout.encoding == 'cp936':
    sys.stdout = UnicodeStreamFilter(sys.stdout)

if __name__ == "__main__":    
    a = "你好"
    b = u"你好"
    print a
    print b


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

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

阅读更多
想对作者说点什么?

博主推荐

换一批

没有更多推荐了,返回首页