linux – 使用Bash中的另一组行过滤行

我的标准输入上有线条

$printf "C\nB\nA\n"
C
B
A

我想过滤掉其他标准输入上出现的行(或子串或正则表达式 – 更容易):

$printf "B\nA\n"
B
A

当条目被过滤时,我希望只有C.

我试过了

$printf "C\nB\nA\n" | grep -v `printf "B\nA\n"`

但后来我得到了

grep: A: No such file or directory

如何通过其他命令返回的行执行标准输入的过滤?

解决方法:

你可以使用grep的-f选项:

Matching Control
    -f FILE, --file=FILE
          Obtain patterns from FILE, one per line.
          [...]

并使用<(命令)语法将命令的输出用作要使用的内容:

$printf "C\nB\nA\nA\nC\nB" | grep -vf <(printf "A\nB\n")
C
C
上一篇:python 统计使用技巧


下一篇:linux – 如何访问子进程的STDIN?