我怎样才能将标准文件压缩到一个文件中,并将标准打印到标准中?

我想执行一个命令,让这个命令的输出在运行中得到gzip,并且回显/输出那个命令的输出。

即类似的东西:

echo "hey hey, we're the monkees" | gzip --stdout > my_log.gz 

除了执行这行之外,我想在标准中看到这个:

 hey hey, we're the monkees 

Solutions Collecting From Web of "我怎样才能将标准文件压缩到一个文件中,并将标准打印到标准中?"

 echo "hey hey, we're the monkees" | tee /dev/tty | gzip --stdout > my_log.gz 

正如在注释中指出的那样,在某些情况下, /dev/stdout可能比/dev/tty更好。

另一种方法(假设一个像bashzsh的shell):

 echo "hey hey, we're the monkees" | tee >(gzip --stdout > my_log.gz) 

毫无疑问奇怪的>()语法基本上做到以下几点:

  • 创建新的FIFO(通常在/tmp/
  • 执行inside ()命令并将FIFO绑定到该子命令的stdin
  • 将FIFO文件名返回到命令行。

那么,最后看到的东西就是这样的:

 tee /tmp/arjhaiX4 

所有gzip看到的是它的标准输入。

对于Bash,请参阅man bash了解详情。 这是在重定向部分。 对于Zsh,请参阅man zshexpn标题为“进程替代”。

据我所知,Korn Shell,经典的Bourne Shell(包括ash和破折号)以及C Shell的变体不支持这种语法。

喝一杯好茶 !

tee命令将标准输入复制到标准输出,也复制到作为参数给出的任何文件。 当你不仅需要在管道上发送一些数据,而且要保存一个副本时,这是非常有用的

由于我的下午时间很短,这里有一些光辉的说明性的ascii艺术…

  +-----+ +---+ +-----+ stdin -> |cmd 1| -> stdout -> |tee| -> stdout -> |cmd 2| +-----+ +---+ +-----+ | v file 

正如greyfade在另一个答案中所表明的那样,“文件”不一定是一个常规的文件,但是可以是FIFO,让你把输出输出到第三个命令中。

  +-----+ +---+ +-----+ stdin -> |cmd 1| -> stdout -> |tee| -> stdout -> |cmd 2| +-----+ +---+ +-----+ | v FIFO | v +-----+ |cmd 3| +-----+ 

只是发布一个不涉及到磁盘的方式:

 echo "hey hey, we're the monkees" | (exec 1>&3 && tee /proc/self/fd/3 | gzip --stdout > my_log.gz)