我有一个程序,将信息写入标准输出和标准错误,我需要用grep处理标准错误,把标准错误放在一边。
使用临时文件,可以分两步完成:
command > /dev/null 2> temp.file
grep 'something' temp.file
但是,在没有临时文件的情况下,如何使用一个命令和管道实现这一点呢?
我有一个程序,将信息写入标准输出和标准错误,我需要用grep处理标准错误,把标准错误放在一边。
使用临时文件,可以分两步完成:
command > /dev/null 2> temp.file
grep 'something' temp.file
但是,在没有临时文件的情况下,如何使用一个命令和管道实现这一点呢?
当前回答
把这些最好的答案结合起来,如果你有:
命令2> >(grep -v something 1>&2)
...然后所有的stdout被保留为stdout,所有的stderr被保留为stderr,但是你不会在stderr中看到任何包含字符串“something”的行。
这有一个独特的优点,即不反转或丢弃stdout和stderr,也不将它们混在一起,也不使用任何临时文件。
其他回答
如果你正在使用Bash,那么使用:
command >/dev/null |& grep "something"
http://www.gnu.org/software/bash/manual/bashref.html#Pipelines
这将重定向command1 stderr到command2 stdin,同时保留command1 stdout原样。
exec 3>&1
command1 2>&1 >&3 3>&- | command2 3>&-
exec 3>&-
摘自LDP
我试着跟着做,发现它也有用,
command > /dev/null 2>&1 | grep 'something'
您可以使用rc外壳。
首先安装包(小于1mb)。
这是一个如何在rc中丢弃标准输出和管道标准错误到grep的例子:
find /proc/ >[1] /dev/null |[2] grep task
你可以在不离开Bash的情况下完成:
rc -c 'find /proc/ >[1] /dev/null |[2] grep task'
您可能已经注意到,可以通过在管道后面使用括号来指定想要管道的文件描述符。
标准文件描述符的编号如下:
0:标准输入 1:标准输出 2:标准错误
把这些最好的答案结合起来,如果你有:
命令2> >(grep -v something 1>&2)
...然后所有的stdout被保留为stdout,所有的stderr被保留为stderr,但是你不会在stderr中看到任何包含字符串“something”的行。
这有一个独特的优点,即不反转或丢弃stdout和stderr,也不将它们混在一起,也不使用任何临时文件。