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')