使用awk或sed在页眉和页脚之间获取文本,但不包括页眉和页脚

假设我有一个文件myfile.txt,其中包含以下内容:

1234
5678
start
stuff
stop
9871

我想获取标题’start’和页脚’stop’之间的数据,但不包括这些边框(所以在这种情况下,我的结果只是行’stuff’).使用awk和sed,我尝试了以下方法:

awk '/start/ { show=1 } show; /stop/ { show=0 }' myfile.txt
 sed -n '/start/,/stop/p' myfile.txt

但这些包括输出中的页眉和页脚.我怎么能这样做,以便我不保留标题和脚 – 但只有中间的信息?

只需颠倒测试的顺序:

$awk '/stop/{show=0} show; /start/ { show=1 }' myfile.txt
stuff

这个怎么运作

> / stop / {show = 0}

每当我们遇到与正则表达式匹配的行时,我们将变量show设置为0(false).
>显示;

如果show为true,则打印该行.

更详细地说,show是一个条件,意味着它被评估,如果是,则执行一个动作.由于我们没有明确指定操作,因此执行默认操作,即打印$0.

由于没有明确指定任何操作,我们需要按照show with;为了将它与下一个命令分开.
> / start / {show = 1}

每当我们遇到与正则表达式开始匹配的行时,我们将变量show设置为1(true).

相关文章
相关标签/搜索