使用bash命令的输出(带管道)作为另一个命令的参数

前端之家收集整理的这篇文章主要介绍了使用bash命令的输出(带管道)作为另一个命令的参数前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在寻找一种方法来使用命令的输出(比如command1)作为另一个命令的参数(比如command2).

我在尝试grep who命令的输出时遇到了这个问题,但是使用了另一组命令给出的模式(实际上是tty piped to sed).

语境:

如果tty显示

/dev/pts/5

显示

root     pts/4        2012-01-15 16:01 (xxxx)
root     pts/5        2012-02-25 10:02 (yyyy)
root     pts/2        2012-03-09 12:03 (zzzz)

目标:

我只想要关于“pts / 5”的行
所以我通过如下方式将tty发送到sed:

$tty | sed 's/\/dev\///'
pts/5

测试:

尝试的以下命令不起作用:

$who | grep $(echo $(tty) | sed 's/\/dev\///')"

可能的方法

我发现以下工作正常:

$eval "who | grep $(echo $(tty) | sed 's/\/dev\///')"

但我确信可以避免使用eval.

作为最后的一个节点:我注意到谁给了我我想要的“-m”参数(只获得链接到当前用户的那一行).但我仍然很好奇如何将管道和命令嵌套组合起来……

你可以在 Bash variable mangling的帮助下不使用sed来做到这一点,尽管@ruakh指出这在单行版本中不起作用(没有用分号分隔命令).我要离开这第一个方法了,因为我觉得有趣的是它不能在一行中起作用:
TTY=$(tty); who | grep "${TTY#/dev/}"

首先将tty的输出放入变量中,然后擦除前导/ dev / on grep对它的使用.但是没有分号TTY在环境中不会出现bash对grep进行变量扩展/修改的情况.

这是一个可行的版本,因为它使用已修改的环境(具有TTY)生成子shell:

TTY=$(tty) WHOLINE=$(who | grep "${TTY#/dev/}")

结果留在$WHOLINE中.

猜你在找的Bash相关文章