gpt4 book ai didi

linux - 使用命令行组合文件的不相邻部分

转载 作者:太空宇宙 更新时间:2023-11-04 04:40:52 25 4
gpt4 key购买 nike

是否可以使用 grep 将文件中的标题行与过滤器的输出连接起来?也许使用 cat 命令或 GNU coreutils 中的其他命令?

特别是,我有一个制表符分隔的文件,大致如下所示:

var1   var2   var3
1 MT 500
30 CA 40000
10 NV 1240
40 TX 500
30 UT 35000
10 AZ 1405
35 CO 500
15 UT 9000
1 NV 1505
30 CA 40000
10 NV 1240

我想使用 grep 从第 2 - N 行中选择包含“CA”的所有行,并使用 GNU/Linux 命令将第一行(变量名称)放置在输出文件的第一行中。

该示例所需的输出是:

var1   var2   var3
30 CA 40000
35 CA 65000
15 CA 2500

我可以使用以下代码行选择两组所需的输出。

head -1 filename
grep -E CA filename

我最初的想法是使用 cat 组合这些命令的输出,但到目前为止我还没有成功。

最佳答案

如果您从 shell 运行命令(包括 shell 脚本),则可以单独运行每个命令并重定向输出:

head -1 filename > outputfile
grep -E CA filename >> outputfile

第一行将覆盖输出文件,因为使用了单个 >。第二行将附加到输出文件,因为使用了 >>。

如果您想在单个命令中执行此操作,则可以在 bash 中执行以下操作:

(head -1 filename && grep -E CA filename) > outputfile

如果您希望输出转到标准输出,请省略括号和重定向:

head -1 filename && grep -E CA filename

关于linux - 使用命令行组合文件的不相邻部分,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30215147/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com