stderr基础

一、从一个c的例子讲起:

void main(){
    fprintf(stdout,"stdout!");
    fprintf(stderr,"stderr!");
    printf("printf!");
}

编译成可执行文件test.out,分别执行,请请观察运行结果

./test.out
./test.out > tmp.txt
./test.out 2> tmp.txt
./test.out &> /dev/null
./test.out >> tmp.txt 2>&1

二、基本概念

  • stdout 标准输出设备(printf(“..”)) 同 stdout。
  • stderr – 标准错误输出设备 两者默认向屏幕输出。

stderr错误非常重要,如果现网程序处理不当,可能会丢失重要信息

三、python实现

python输出stdout,stderr

import sys

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

python 捕获shell的stderr

import subprocess

# 执行shell命令,通过subprocess来获取stdout和stderr的值
def exec_shell(cmd):
    child = subprocess.Popen(cmd, shell=True, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
    child.poll()  # 检查子进程状态
    print child.stdout.read() # 不会自带换行
    print child.stderr.read()

四、进阶思考

  • stdout和stderr到screen的顺序
  • python执行shell命令建议都用subprocess,而不是os.system()

参考内容:


腾讯云+社区 文章链接:https://cloud.tencent.com/developer/article/1148446

猜你喜欢

转载自blog.csdn.net/u013128262/article/details/80725291