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

参考内容:

原创声明,本文系作者授权云+社区发表,未经许可,不得转载。

如有侵权,请联系 yunjia_community@tencent.com 删除。

编辑于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏杨龙飞前端

scrollto 到指定位置

2504
来自专栏张善友的专栏

Silverlight + Model-View-ViewModel (MVVM)

     早在2005年,John Gossman写了一篇关于Model-View-ViewModel模式的博文,这种模式被他所在的微软的项目组用来创建Expr...

2968
来自专栏Golang语言社区

【Golang语言社区】GO1.9 map并发安全测试

var m sync.Map //全局 func maintest() { // 第一个 YongHuomap := make(map[st...

4708
来自专栏张善友的专栏

Miguel de Icaza 细说 Mix 07大会上的Silverlight和DLR

Mono之父Miguel de Icaza 详细报道微软Mix 07大会上的Silverlight和DLR ,上面还谈到了Mono and Silverligh...

2707
来自专栏一个爱瞎折腾的程序猿

sqlserver使用存储过程跟踪SQL

USE [master] GO /****** Object: StoredProcedure [dbo].[sp_perfworkload_trace_s...

2060
来自专栏转载gongluck的CSDN博客

cocos2dx 打灰机

#include "GamePlane.h" #include "PlaneSprite.h" #include "BulletNode.h" #include...

5456
来自专栏Ceph对象存储方案

Luminous版本PG 分布调优

Luminous版本开始新增的balancer模块在PG分布优化方面效果非常明显,操作也非常简便,强烈推荐各位在集群上线之前进行这一操作,能够极大的提升整个集群...

3145
来自专栏张善友的专栏

Mix 10 上的asp.net mvc 2的相关Session

Beyond File | New Company: From Cheesy Sample to Social Platform Scott Hansel...

2577
来自专栏大内老A

The .NET of Tomorrow

Ed Charbeneau(http://developer.telerik.com/featured/the-net-of-tomorrow/) Exciti...

31710
来自专栏陈仁松博客

ASP.NET Core 'Microsoft.Win32.Registry' 错误修复

今天在发布Asp.net Core应用到Azure的时候出现错误InvalidOperationException: Cannot find compilati...

4848

扫码关注云+社区