bash – sed / awk – 在跨越多行的模式之间打印文本

我是脚本新手,并且正在尝试学习如何提取两种不同模式之间存在的任何文本.但是,在以下场景中,我仍然无法弄清楚如何在两种模式之间提取文本:

如果我的输入文件读取:

Hi I would like
to print text
between these 
patterns

我的预期输出如下:

I would like
to print text
between these

即我的第一个搜索模式是“嗨”并跳过此模式,但打印出匹配模式后面的同一行中存在的所有内容.我的第二个搜索模式是“模式”,我想完全避免打印此行或超出任何行那.

我尝试了以下方法

sed -n '/Hi/,/patterns/p' test.txt

[输出]

Hi I would like
to print text
between these 
patterns

接下来,我试过:

`awk ' /'"Hi"'/ {flag=1;next} /'"pattern"'/{flag=0} flag { print }'` test.txt

[输出]

to print text
between these

有人可以帮助我确定如何实现这一目标吗?
提前致谢

你有正确的想法,awk中的迷你状态机,但你需要一些轻微的mods,如下面的记录:
pax> echo 'Hi I would like
to print text
between these 
patterns ' | awk '
    /patterns/ { echo = 0 }
    /Hi /      { gsub("^.*Hi ","",$0); echo = 1 }
               { if (echo == 1) { print } }'

或者,以压缩形式:

awk '/patterns/{e=0}/Hi /{gsub("^.*Hi ",$0);e=1}{if(e==1){print}}'

输出是:

I would like
to print text
between these

按照要求.

这种方式的工作方式如下. echo变量最初为0意味着不会发生回声.

依次检查每一行.如果它包含模式,则禁用回显.

如果它包含Hi后跟一个空格,则打开echo,并使用gsub修改该行以除去Hi之外的所有内容.

然后,无论如何,当回波标志打开时,回显(可能已修改)线.

现在,将出现边缘情况,例如:

>包含两次Hi的行;要么
>在模式之前包含某些内容的行.

你还没有具体说明它们应该如何处理,所以我没有打扰,但基本概念应该是相同的.

相关文章

用的openwrt路由器,家里宽带申请了动态公网ip,为了方便把2...
#!/bin/bashcommand1&command2&wait从Shell脚本并行...
1.先查出MAMP下面集成的PHP版本cd/Applications/MAMP/bin/ph...
1、先输入locale-a,查看一下现在已安装的语言2、若不存在如...
BashPerlTclsyntaxdiff1.进制数表示Languagebinaryoctalhexa...
正常安装了k8s后,使用kubect工具后接的命令不能直接tab补全...