[英]How to print the next word after a found pattern with grep,sed and awk?
[英]Modify the contents of a text file after a pattern has been found using sed/awk commands
我试图提出一个Tcl脚本,但是我正在sed / awk命令中寻找一些东西来使它更快。
该文件包含以下内容:
*Other text*
.....
.....
.....
SECTION LABELS {
lab M1 0 0 0 0 3 1 bot
lab M2 0 0 0 0 3 1 top
} SECTION LABELS
*Other text*
......
......
......
SECTION LABELS {
lab M1:NET 5207 12261 5207 12261 0 2 A
lab M2:NET 6880 5370 6880 5370 0 2 B
lab M1:NET 3454 5386 3454 5386 0 2 alpha
lab M2:NET 3454 5386 3454 5386 0 2 beta
} SECTION LABELS
我只对“ SECTION LABELS”中包含的行感兴趣。 我想:
所以输出看起来像:
*Other text*
.....
.....
.....
SECTION LABELS {
lab M1 0 0 0 0 3 1 bot
lab M2 0 0 0 0 3 1 top
} SECTION LABELS
*Other text*
......
......
......
SECTION LABELS {
lab M1 5207 12261 5207 12261 0 3 A
lab M2 6880 5370 6880 5370 0 3 B
lab M1 3454 5386 3454 5386 0 6 alpha
lab M2 3454 5386 3454 5386 0 6 beta
} SECTION LABELS
以下是一些入门指南:
awk '/SECTION LABELS/ {f=!f} f && /NET/ && !/lab M1(:NET)* 0 0 0 0/ {split($2,a,":");$2=a[1];if ($NF~/\<[A|B]\>/) $(NF-1)=3; else $(NF-1)=6}1' t
*Other text*
.....
.....
.....
SECTION LABELS {
lab M1 0 0 0 0 3 1 bot
lab M2 0 0 0 0 3 1 top
} SECTION LABELS
*Other text*
......
......
......
SECTION LABELS {
lab M1 5207 12261 5207 12261 0 3 A
lab M2 6880 5370 6880 5370 0 3 B
lab M1 3454 5386 3454 5386 0 6 alpha
lab M2 3454 5386 3454 5386 0 6 beta
} SECTION LABELS
您可以将范围用作模式,然后对介于两者之间(包括两端)的文本进行操作。 供您输入:
awk '/^SECTION LABELS {/,/} SECTION LABELS/{
sub(":NET","")
if ($8 && !/M1 0 0 0 0/) $8 = ($NF ~ /^[AB]$/) ? 3 : 6
}1' file.txt
注意:(1)如果“ SECTION LABELS”中的单词超过7个,则需要调整“ if”部分(我想这只是一个示例)。 您可以将'$ 8'更改为'$ 9'或$ 9!=“”等,以跳过标题和尾部。
(2)如果A,B是字符串而不是字符,则需要将正则表达式从^ [AB] $更改为^(A | B)$
(3)如果还想保持M2 0 0 0 0不变,则将!/ M1 0 0 0 0 /更改为!/ \\ <0 0 0 0 \\> /,其中'\\ <'和'\\>'为正则表达式中的单词边界。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.