Stdout encoding in python

前端 未结 1 1026
不知归路
不知归路 2020-12-31 06:39

Is there a good reason why I shouldn\'t start all my python programs with this? Is there something special lost when doing exec like this?

#         


        
相关标签:
1条回答
  • 2020-12-31 07:19

    Yes, there is a good reason not to start all your Python programs like that.

    First of all:

    sys.stdout.encoding is None if Python doesn't know what encoding the stdout supports. This, in most cases, is because it doesn't really support any encoding at all. In your case it's because the stdout is a file, and not a terminal. But it could be set to None because Python also fails to detect the encoding of the terminal.

    Second of all: You set the environment variable and then start a new process with the smae command again. That's pretty ugly.

    So, unless you plan to be the only one using your programs, you shouldn't start them like that. But if you do plan to be the only using your program, then go ahead.

    More in-depth explanation

    A better generic solution under Python 2 is to treat stdout as what it is: An 8-bit interface. And that means that anything you print to to stdout should be 8-bit. You get the error when you are trying to print Unicode data, because print will then try to encode the Unicode data to the encoding of stdout, and if it's None it will assume ASCII, and fail, unless you set PYTHONIOENCODING.

    But by printing encoded data, you don't have this problem. The following works perfectly even when the output is piped:

    print u'ÅÄÖ'.encode('UTF8')
    

    (However, this will fail Under Python 3, because under Python 3, stdout is no longer 8-bit IO, you are supposed to give it Unicode data, and it will encode by itself. If you give it binary data, it will print the representation. Therefore on Python 3 you don't have this problem in the first place).

    0 讨论(0)
提交回复
热议问题