sys stderr作用

sys.stderr 是用来重定向标准错误信息的,如

import sys

print 'this error'

sys.stderr.write("this is a error message")

 

在linux 运行时

python xx.py 2>/error.log

由于命令行的2只有记录错误到文件,所以 error.log就会记录sys.stderr输出的错误信息,而不会记录print 的,当然也能记录到raise

文件 文件描述符 
输入文件 0
输出文件 1
错误输出文件 2

如goagent的proxy.py模块对sys.stderr的用法

try:
    import gevent
    import gevent.queue
    import gevent.monkey
    import gevent.coros
    import gevent.server
    import gevent.pool
    import gevent.event
    import gevent.timeout
    gevent.monkey.patch_all(dns=gevent.version_info[0]>=1)
except ImportError:
    if os.name == 'nt':
        sys.stderr.write('WARNING: python-gevent not installed. `https://github.com/SiteSupport/gevent/downloads`\n')
    else:
        sys.stderr.write('WARNING: python-gevent not installed. `curl -k -L http://git.io/I9B7RQ|sh`\n')

  

 

posted @ 2013-04-12 13:48  践道者  阅读(15170)  评论(0编辑  收藏  举报